javascript - Angular2 和 Turbolinks

标签 javascript typescript angular systemjs

情况是这样的:我正在使用异步。使用 systemJS 加载脚本(通过脚本,我指的是 jQuery、Angular2 等)。现在我想在其中实现 Turbolinks。一切正常,但我的 Angular 组件只在第一次渲染。如果我使用 Turbolinks 查看下一页,我的组件不会呈现。对象检查器和源代码中没有错误只是这样的:

<search-app></search-app>

我已经厌倦了在对象检查器中的测试,但在第二页引导之后,这只是 HTML 标记。

这是我在页面 Head 标记中用 SystemJS 加载的脚本:

System.config({

            meta: {
                '/bundles/frontall': { format: 'global' },
                '/bundles/raphael': { format: 'global' },
                '/bundles/zopim': { format: 'global' },
                '/bundles/angular2': { format: 'global' }
            },

            packages: {
                'angular': {
                    format: 'register',
                    defaultExtension: 'js'
                },

                'angular2': {
                    format: 'global',
                    defaultExtension: 'js'
                },

                'rxjs': {
                    format: 'global',
                    defaultExtension: 'js'
                }
            },

            paths: {
                'angular2/*': 'scripts/angular2/*',
                'rxjs/*': 'scripts/rxjs/*'
            }
        });


         System.import('/bundles/frontall').then(function () {
            Promise.all([
                System.import('/bundles/zopim'),
                System.import('/bundles/raphael'),
                System.import('bundles/angular2'),
                @RenderSection("asyncScripts", required: false)
            ]).then(function () {

            System.import('angular/searchApp');
        });

在所有包的前面是文件 site.js,我在其中重新初始化所有组件:

function componentInit() {

//init material design
$.material.init();

//init texarea autosize
autosize($('textarea'));

//init parallax
$('.parallax-window').parallax();

//init smooth scroll
//SmoothScroll();

//init css3 animate it
$.animateIt();
$.doTimeout();
$.animateItInit();

$.srSmoothscroll({
    step: 80,
    speed: 90,
    ease: 'linear',
    target: $('body'),
    container: $(window)
});  
}

$(function () {
    componentInit();

});

$(document).on('page:load', function () {
    componentInit();
});

Angular 2 版本是 beta 7。有人知道问题出在哪里吗?非常感谢!

最佳答案

我需要将它添加到我的 angular2 应用程序并且它可以工作:

jQuery(function () { 
    bootstrap(searchApp, [ElementRef, TournamentSearchService]); 
}); 
jQuery(document).on('page:load', function () { 
    bootstrap(searchApp, [ElementRef, TournamentSearchService]); 
}); 

关于javascript - Angular2 和 Turbolinks,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35780120/

相关文章:

javascript - ng-click 在使用参数调用函数时出现 "href undefined "错误

javascript - 如果 JS 中的函数是一等的,那么是什么允许它们在定义之前被调用?

javascript - 如何创建一组相同的值

typescript - 在 TypeScript 的异步函数中返回 promise

reactjs - react 功能组件静态属性

angular - 模拟与服务的依赖关系导致 firebase 错误

javascript - Angular4 无法向 yii2 应用程序发送发布请求

javascript - onsubmit 不调用 javascript 函数

angular - 构建 Angular 库时包含 Assets

javascript - querySelector 和 querySelectorAll 别名