6

我有一个 Angular 2 应用程序 (RC7),它以单个组件开始,但很快以各种不同(有时完全不相关)的方式在整个项目中使用。

因此,单个NgModule引导所有组件似乎是一个糟糕的想法,并且会产生大量膨胀。我正在努力寻找一种拥有多个模块的方法(模块 A 将包含组件 A,模块 B 将包含组件 B 等),并且仍然允许在单个页面上引导多个 A2 应用程序。

在实践中,我想要实现的是:

第 1 页引导模块 A -这有效

第 2 页引导模块 B -这有效

第 3 页引导模块 A 和模块 B -这不起作用

索引.html

<script src="/angular2/node_modules/zone.js/dist/zone.js"></script>
<script src="/angular2/node_modules/reflect-metadata/Reflect.js"></script>
<script src="/angular2/node_modules/systemjs/dist/system.src.js"></script>
<script src="/angular2/systemjs.config.js"></script>


<script type="text/javascript">
    System.import('appOne').catch(function(err){ console.error(err); });
    System.import('appTwo').catch(function(err){ console.error(err); });
</script>

systemjs.config.js

(function (global) {
    System.config({
        paths: {
            'npm:': '/angular2/node_modules/'
        },
        map: {
            appOne: '/angular2/',
            appTwo: '/angular2/',
        },
        packages: {
            appOne: {
                main: './appOne.main.js',
                defaultExtension: 'js'
            },
            appTwo: {
                main: './appTwo.main.js',
                defaultExtension: 'js'
            },
        }
    });
})(this);

AppOne 和 AppTwo 的模块只是简单地引导相关组件(componentOne 和 componentTwo)。但是,两者不会同时呈现在同一页面上。我在控制台中没有错误,但是 systemjs.config.js 文件中最后列出的包是唯一要加载的包。

谁能明白为什么它可能不起作用?或者也许推荐另一种方式来构建我的模块。我宁愿不列出一个包含所有组件、服务等的父模块——这似乎违背了 Angular 2 嵌套组件树的要点,并最终会成倍地影响页面加载时间。

提前致谢。

4

3 回答 3

5

您可以从 AppModule 中引导一组组件,如下所示:

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import {AppComponent} from "./app.component";
import {MainSidebarComponent} from "./menus/main-sidebar.component";
import {FormsModule} from "@angular/forms";
import {appRouting} from "./app.routes";
import {DashBoardComponent} from "./dashboard/dashboard.component";
import {HomeComponent} from "./home/home.component";
import {LoginComponent} from "./login/login.component";
import {UsersModule} from "./users/users.module";
import {TopBarComponent} from "./menus/top-bar.component";

@NgModule({
    imports:      [
        BrowserModule,
        FormsModule,
        appRouting,

        UsersModule
    ],
    declarations: [
        AppComponent,
        MainSidebarComponent,
        TopBarComponent,
        DashBoardComponent,
        HomeComponent,
        LoginComponent
    ],
    bootstrap:    [ AppComponent, MainSidebarComponent, TopBarComponent ]
})
export class AppModule { }

然后在你的 index.html

<!doctype html>
<head>
    <base href="/">
    <meta charset="UTF-8">

    <!-- 1. Load libraries -->
    <!-- Polyfill(s) for older browsers -->
    <script src="node_modules/core-js/client/shim.min.js"></script>
    <script src="node_modules/zone.js/dist/zone.js"></script>
    <script src="node_modules/reflect-metadata/Reflect.js"></script>
    <script src="node_modules/systemjs/dist/system.src.js"></script>
    <!-- 2. Configure SystemJS -->
    <script src="systemjs.config.js"></script>
    <script>
        System.import('app').catch(function (err) {
            console.error(err);
        });
    </script>
</head>
<body class=" sidebar_main_open sidebar_main_swipe">

<header id="header_main">
 <top-bar></top-bar>
</header><


<aside id="sidebar_main">
    <main-sidebar></main-sidebar>
</aside>


<div id="page_content">
    <div id="page_content_inner">
        <my-app>Loading....</my-app>
    </div>
</div>
</body>
</html>
于 2016-11-01T13:31:37.207 回答
4

对于任何感兴趣的人来说,问题是引导。这两个应用程序必须一致地引导才能工作。

索引.html

<script src="/angular2/node_modules/zone.js/dist/zone.js"></script>
<script src="/angular2/node_modules/reflect-metadata/Reflect.js"></script>
<script src="/angular2/node_modules/systemjs/dist/system.src.js"></script>
<script src="/angular2/systemjs.config.js"></script>


<script type="text/javascript">
    System.import('appOneAndTwo').catch(function(err){ console.error(err); });
</script>

systemjs.config.js

(function (global) {
    System.config({
        paths: {
            'npm:': '/angular2/node_modules/'
        },
        map: {
            appOne: '/angular2/',
            appTwo: '/angular2/',
            appOneAndTwo: '/angular2/',
        },
        packages: {
            appOne: {
                main: './appOne.main.js',
                defaultExtension: 'js'
            },
            appTwo: {
                main: './appTwo.main.js',
                defaultExtension: 'js'
            },
            appOneAndTwo: {
                main: './appOneAndTwo.main.js',
                defaultExtension: 'js'
            },
        }
    });
})(this);

appOneAndTwo.main.ts

import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import {AppOneModule} from './app/app.one.module';
import {AppTwoModule} from './app/app.two.module';

platformBrowserDynamic().bootstrapModule(CommentAppModule);
platformBrowserDynamic().bootstrapModule(WorkflowAppModule);

它仍然不理想,因为我必须为我创建的每个 Angular 2 应用程序组合创建一个新的main.ts文件,但这确实意味着导入仅在必要时严格导入,并且有效负载不会膨胀到最终用户。

我目前正在研究 AoT 编译器 ( https://angular.io/docs/ts/latest/cookbook/aot-compiler.html ) 和使用 Webpack 的 uglification/minification 以进一步减少有效负载大小。

于 2016-10-04T09:31:23.567 回答
0

我不知道您是否可以实现您想要的确切解决方案,但您可以尝试延迟加载您的一些模块。

例如,您创建一个 AppModule(用于引导)。在 AppModule 中,你只导入你的“home”模块(我称之为 HomeModule)。

比所有其他模块都可以延迟加载(参考

于 2016-10-03T17:45:58.953 回答