91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Angular HMR(熱模塊替換)功能實現方法

發布時間:2020-10-14 06:37:30 來源:腳本之家 閱讀:174 作者:滅蒙鳥 欄目:web開發

最近一個同事在使用Angular的時候,希望能像VUE那樣,修改代碼后瀏覽器不刷新,頁面對應修改的組件自動更新的功能。這個功能的名字時HMR (hot module replace)。

稍微研究了一下,發現在angular/cli創建的項目中,實現這個不算太難,步驟如下:

1、首先創建一個src/environments/environment.hmr.ts文件,內容如下

export const environment = {
 production: false,
 hmr: true
};

當然,對應的environment.prod.ts和environment.ts需要增加一個hmr:false.

如果environment.ts里面的hmr設置為ture,那么ng serve --hmr也有同樣效果。不過我對熱替換功能還不是那么相信,重新刷新瀏覽器能保證狀態更加干凈一些,所以讓environment.ts中的hmr為false.

2、在.angular-cli.json文件的環境中增加hmr的環境,大致如下:

"environments": {
 ...
 "hmr": "environments/environment.hmr.ts",
}

3、在package.json的scripts中增加一個新的命令。(當然也可以不增加,直接運行ng serve --hmr -e=hmr和運行npm run hmr效果一樣)

"scripts": {
 ...
 "hmr": "ng serve --hmr -e=hmr"
}

4、安裝hmr模塊,命令如下:

npm install --save-dev @angularclass/hmr

5、創建src\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(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();
 });
};

這事熱替換的關鍵,hmrBootstrap會替換原始的bootstrap(下面會看到), 替換后,當有新的模塊更新時,hmr會首先移除掉舊有的模塊,然后接收新的模塊。這些都是發生在瀏覽器里面。所以頁面不會刷新。

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();
}

這里替換就得啟動文件,如果設置為hmr,那么調用hmrBootStrap來啟動網頁,否則就用過去的

7、現在運行npm run hmr或者ng serve --hmr -e=hmr,就實現了熱替換功能。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

晴隆县| 恩施市| 金乡县| 高邮市| 大余县| 左云县| 清原| 高台县| 碌曲县| 保靖县| 葫芦岛市| 凯里市| 黑河市| 三台县| 涞源县| 方城县| 托克逊县| 缙云县| 八宿县| 塘沽区| 含山县| 平顶山市| 丰宁| 卓尼县| 西青区| 册亨县| 铜川市| 英德市| 农安县| 手游| 罗平县| 阿坝县| 盐城市| 玉树县| 年辖:市辖区| 沅江市| 龙江县| 巧家县| 老河口市| 屏东县| 武宁县|