1.安装hmr依赖
npm i --save-dev @angularclass/hmr
2.src/environments/environment.hmr.ts - 添加environment.hmr.ts配置文件
export const environment = {
production: false,
hmr: true
}
3.在 environment.prod.ts 和 environment.ts 两个文件中添加 hmr:false
4.src/hmr.ts - 添加hmr.ts文件
import { NgModuleRef, ApplicationRef } from '@angular/core';
import { createNewHosts } from '@angularclass/hmr';
export const hmrBootstrap = (
module: any,
bootstrap: () => Promise<NgModuleRef<any>>
) => {
let ngModule: NgModuleRef<any>;
module.hot.accept();
bootstrap().then(mod => (ngModule = mod));
module.hot.dispose(() => {
const appRef: ApplicationRef = ngModule.injector.get(ApplicationRef);
const elements = appRef.components.map(c => c.location.nativeElement);
const makeVisible = createNewHosts(elements);
ngModule.destroy();
makeVisible();
});
};
5.配置angular.json文件
configurations 对象:
"hmr": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.hmr.ts"
}
]
}
serve对象:
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "hmr-angular:build"
},
"configurations": {
"production": {
"browserTarget": "hmr-angular:build:production"
},
"hmr": {
"browserTarget": "hmr-angular:build:hmr",
"hmr": true
}
}
6.package.json - 新增启动命令
"hmr": "ng serve -c=hmr --disable-host-check"
运行 npm run hmr
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。