使用angular-cli webpack创建多个捆绑包

21

使用 angular-cli 构建项目时,它会将所有项目文件捆绑成一个大的主包。

我在应用程序中使用了惰性路由,在应用程序加载后可以正常导航。

是否有一种方法可以根据惰性加载路由模块将主 bundle 分成多个文件?

下面是 angular-cli.json 的配置:

    {
  "project": {
    "version": "1.0.0-beta.15",
    "name": "maddy-test-project"
  },
  "apps": [
    {
      "root": "src",
      "outDir": "dist",
      "assets": "styles/content",
      "index": "default.htm",
      "main": "main.ts",
      "test": "test.ts",
      "tsconfig": "tsconfig.json",
      "prefix": "",
      "mobile": false,
      "styles": [
        "styles.less"
      ],
      "scripts": [
        "styles/wfa-myriad-pro-typekit.js"
      ],
      "environments": {
        "source": "environments/environment.ts",
        "dev": "environments/environment.ts",
        "prod": "environments/environment.prod.ts"
      }
    }
  ],
  "addons": [],
  "packages": [],
  "e2e": {
    "protractor": {
      "config": "./protractor.conf.js"
    }
  },
  "test": {
    "karma": {
      "config": "./karma.conf.js"
    }
  },
  "defaults": {
    "styleExt": "less",
    "prefixInterfaces": false
  }
}

以下是 package.json 文件

{
  "name": "maddy-test-project",
  "version": "0.0.1",
  "license": "MIT",
  "angular-cli": {},
  "scripts": {
    "start": "ng serve",
    "lint": "tslint \"src/**/*.ts\"",
    "test": "ng test",
    "pree2e": "webdriver-manager update",
    "e2e": "protractor"
  },
  "private": true,
  "dependencies": {
    "@angular/common": "2.0.0",
    "@angular/compiler": "2.0.0",
    "@angular/core": "2.0.0",
    "@angular/forms": "2.0.0",
    "@angular/http": "2.0.0",
    "@angular/platform-browser": "2.0.0",
    "@angular/platform-browser-dynamic": "2.0.0",
    "@angular/router": "3.0.0",
    "d3": "^4.2.3",
    "jquery": "^3.1.0",
    "lodash": "^4.15.0",
    "moment": "^2.15.0",
    "core-js": "^2.4.1",
    "rxjs": "5.0.0-beta.12",
    "toastr": "^2.1.2",
    "ts-helpers": "^1.1.1",
    "zone.js": "^0.6.23",  
    "bootstrap-daterangepicker": "^2.1.24"
  },
  "devDependencies": {
    "@types/d3": "^3.5.35",
    "@types/google-maps": "^3.1.27",
    "@types/jasmine": "^2.2.30",
    "@types/jquery": "^1.10.31",
    "@types/lodash": "^4.14.34",
    "@types/toastr": "^2.1.29",
    "angular-cli": "1.0.0-beta.15",
    "codelyzer": "~0.0.26",
    "jasmine-core": "2.4.1",
    "jasmine-spec-reporter": "2.5.0",
    "karma": "1.2.0",
    "karma-chrome-launcher": "^2.0.0",
    "karma-cli": "^1.0.1",
    "karma-jasmine": "^1.0.2",
    "karma-remap-istanbul": "^0.2.1",
    "protractor": "4.0.5",
    "ts-node": "1.2.1",
    "tslint": "3.13.0",
    "typescript": "2.0.2"
  }
}

提前致谢!

2个回答

9
这与 NgModule RouterModule.forChild() 的角色有关。以下是一篇非常好的文章,可用于开始大型Angular 2模块应用程序开发:http://blog.angular-university.io/angular2-ngmodule/

我们需要做的第一件事是从App组件和主路由配置中删除Home组件或HomeModule的每个提及:

我们可以看到这里App组件不再导入HomeModule,而是路由配置使用loadChildren来指示如果碰到/home或任何其他以它开头的url,则应通过Ajax调用加载home.module文件。

简而言之,要将某些逻辑和组件移动到惰性模块中,您可以运行以下命令:

ng g module child --routing

然后,angular-cli将会生成一个NgModule (app/child/child.module.ts) 和一个子路由配置 (app/child/child-routing.module.ts)。

懒加载该子路由的路由为:

 { path: 'child', loadChildren: 'app/child/child.module#ChildModule' }

最后,将您在ChildModule中需要的内容移动到一个约束条件中:其他模块(如AppModule)将无法使用任何ChildModule依赖项(例如服务)。如果您需要它,一个好的做法是创建一个共享模块。


自beta.24版本开始(beta.23未发布),ng g module child将不再生成组件。我们需要使用ng g module child --routing - Timathon
谢谢你的回答。我还需要知道一件事,你是怎么知道“ng g module child将不再生成组件,因为beta.24”?是否有任何文档可以获取这些关于angular-cli重要发布信息的内容? - Partha Sarathi Ghosh
组件生成是可选的,与模块生成无关。这是一个功能(https://github.com/angular/angular-cli/pull/3389),在 beta 23 中引入(正如 @Timathon 所说的那样),但并未发布:https://github.com/angular/angular-cli/blob/master/CHANGELOG.md#100-beta23-2016-12-15。在 beta 24 中,默认情况下会生成组件。 - Karbos 538

4
如果您将想要进行懒加载的区域拆分为单独的模块,应该能够生成多个捆绑包。请查看直接从angular.io网站获取的路由和导航的plnkr。 如果您以这种方式配置路由,则在运行ng serve时应该能够生成类似于以下内容的构建:
enter image description here 请注意块文件。在我的项目中,当导航到“crisis”和“heroes”路由时,这些块文件会异步加载。
export const routes: Routes = [
  { path: '', redirectTo: 'contact', pathMatch: 'full'},
  { path: 'crisis', loadChildren: 'app/crisis/crisis.module#CrisisModule' },
  { path: 'heroes', loadChildren: 'app/hero/hero.module#HeroModule' }
];

2
如何使用Webpack进行代码块分割? - aWebDeveloper

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接