Angular HMR(熱模塊替換)功能實現(xiàn)方法
最近一個同事在使用Angular的時候,希望能像VUE那樣,修改代碼后瀏覽器不刷新,頁面對應(yīng)修改的組件自動更新的功能。這個功能的名字時HMR (hot module replace)。
稍微研究了一下,發(fā)現(xiàn)在angular/cli創(chuàng)建的項目中,實現(xiàn)這個不算太難,步驟如下:
1、首先創(chuàng)建一個src/environments/environment.hmr.ts文件,內(nèi)容如下
export const environment = {
production: false,
hmr: true
};
當(dāng)然,對應(yīng)的environment.prod.ts和environment.ts需要增加一個hmr:false.
如果environment.ts里面的hmr設(shè)置為ture,那么ng serve --hmr也有同樣效果。不過我對熱替換功能還不是那么相信,重新刷新瀏覽器能保證狀態(tài)更加干凈一些,所以讓environment.ts中的hmr為false.
2、在.angular-cli.json文件的環(huán)境中增加hmr的環(huán)境,大致如下:
"environments": {
...
"hmr": "environments/environment.hmr.ts",
}
3、在package.json的scripts中增加一個新的命令。(當(dāng)然也可以不增加,直接運(yùn)行ng serve --hmr -e=hmr和運(yùn)行npm run hmr效果一樣)
"scripts": {
...
"hmr": "ng serve --hmr -e=hmr"
}
4、安裝hmr模塊,命令如下:
npm install --save-dev @angularclass/hmr
5、創(chuàng)建src\hmr.ts文件,內(nèi)容如下:
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(currentModule => ngModule = currentModule);
module.hot.dispose(() => {
const appRef: ApplicationRef = ngModule.injector.get(ApplicationRef);
const elements = appRef.components.map(c => c.location.nativeElement);
const removeOldHosts = createNewHosts(elements);
ngModule.destroy();
removeOldHosts();
});
};
這事熱替換的關(guān)鍵,hmrBootstrap會替換原始的bootstrap(下面會看到), 替換后,當(dāng)有新的模塊更新時,hmr會首先移除掉舊有的模塊,然后接收新的模塊。這些都是發(fā)生在瀏覽器里面。所以頁面不會刷新。
6、更新src\main.ts文件如下:
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
import { hmrBootstrap } from './hmr';
if (environment.production) {
enableProdMode();
}
const bootstrap = () => platformBrowserDynamic().bootstrapModule(AppModule);
if (environment.hmr) {
if (module[ 'hot' ]) {
hmrBootstrap(module, bootstrap);
} else {
console.error('Ammm.. HMR is not enabled for webpack');
}
} else {
bootstrap();
}
這里替換就得啟動文件,如果設(shè)置為hmr,那么調(diào)用hmrBootStrap來啟動網(wǎng)頁,否則就用過去的
7、現(xiàn)在運(yùn)行npm run hmr或者ng serve --hmr -e=hmr,就實現(xiàn)了熱替換功能。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Angular應(yīng)用里環(huán)境變量SERVER_REQUEST_ORIGIN含義解析
這篇文章主要為大家介紹了Angular應(yīng)用里環(huán)境變量SERVER_REQUEST_ORIGIN的含義解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
淺析angularJS中的ui-router和ng-grid模塊
下面小編就為大家?guī)硪黄獪\析angularJS中的ui-router和ng-grid模塊。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05
詳解AngularJS中$filter過濾器使用(自定義過濾器)
這篇文章主要介紹了詳解AngularJS中$filter過濾器使用(自定義過濾器)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
angular和BootStrap3實現(xiàn)購物車功能
這篇文章主要為大家詳細(xì)介紹了angular和BootStrap3實現(xiàn)購物車功能的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01

