热模块替换(HMR)是一种WebPack功能,用于更新正在运行的应用程序中的代码而无需重建它。这样可以加快更新速度并减少整页重新加载。
为了让HMR使用Angular CLI,我们首先需要添加一个新环境并启用它。
1.HMR添加依赖项并配置app
- 安装hmr依赖环境
$ npm install --save-dev @ angularclass / hmr |
- 创建一个src/hmr.ts使用以下内容作为配置
import { NgModuleRef, ApplicationRef } from '@angular/core'; |
- 修改main.ts文件的配置为以下内容
import { enableProdMode } from '@angular/core'; |
2.配置HMR环境变量
创建一个src/environments/environment.hmr.ts使用以下内容调用的文件:
export const environment = { |
更新src/environments/environment.prod.ts并将hmr: false标志添加到环境中:
export const environment = { |
更新src/environments/environment.ts并将hmr: false标志添加到环境中:
export const environment = { |
接下来,配置angular.json,此处 <project-name>
为你的项目名称;
{ |
修改src/tsconfig.app.json
{ |
我们可以在pack.json中做以下配置方便我们在实际开发中更好的工作,这里使用4205端口,是方便我们启动多个项目时,防止端口重复,可以根据自己的需要具体修改配置,以下仅供参考;"scripts": {
...
"hmr": "ng serve --configuration hmr --open --port 4205"
},
$ npm run hmr |