写在前面
为了让 Angular 类库应用范围更自由,Angular 提出一套打包格式建议名曰:Angular Package Format,包括 FESM2015、FESM5、UMD、ESM2015、ESM5、ES2015 格式,不同格式可以在不同的环境(Angular Cli、Webpack、SystemJS等)中使用。
传统方式需要对这些格式逐一打包,一个示例打包脚本写法。这种写法只能针对不同项目的配置,而且除非你了解这些格式的本质否则很难维护;后来社区根据 APF 规范实现了类库 ng-packagr,通过简单的配置可以将你的类库打包成 APF 规范格式。
至 V6 以后 Angular Cli 也基于 ng-packagr 实现了另一个 @angular-devkit/build-ng-packagr 应用构建器。
如何使用
既然 ng-packagr 被 Angular Cli 内置,这让我们进一步简化了生产一个 APF 规范格式的类库的成本。在 Angualr Cli 里使用 ng g library
来创建一个类库模板,例如在一个新的 Angular 应用里执行:
ng g library <library name>
而打包,则:
ng build <library name>
最终,将生成的 dist/<libary name>
目录下文件上传相应包管理服务器(例如:npm)提供给其他 人使用。
配置说明
由 Angular Cli 生成的类库模板大部分内容同 Angular 应用一样,只是多了一个 ng-package.json
的配置文件(对于生产环境是 ng-package.prod.json
),它是专门针对 ng-packagr 的一个配置文件,如同 angular.json 一般也是基于 JSON Schema 格式,因此可以通过访问ng-package.schema.json 了解所有细节,以下描述一些重点项。
whitelistedNonPeerDependencies
ng-packagr 默认会根据 package.json 的 peerDependencies
节点清单来决定类库所需要第三方依赖包,这些依赖包是不会被打包至类库。
然而,所依赖包不存在 peerDependencies
节点里时(当然建议需要依赖的项应该在里面),就需要该属性的配置。
lib/entryFile
指定入口文件。
lib/umdModuleIds
UMD 格式采用 rollup 打包,当类库需要引用一些无法猜出正确 UMD 标识符时,就需要你手动映射这些类库的标识。
"umdModuleIds": { "lodash": "_"}
angular.json
Angular Cli 配置文件 angular.json 内会增加一个以 <libary name>
命名的构建配置,绝大多数配置性同普通 Angular 应用如出一辙,唯一不同的是 builder
节点为:
"builder": "@angular-devkit/build-ng-packagr:build"
次级入口
有时候一个类库可能会包含着多个二次入口,就像 @angular/core
类库包含着一个 @angular/core/testing
模块,它只是运用于测试,因此并不希望在项目中引入 @angular/core
新闻热点
疑难解答
图片精选