欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular HMR(熱模塊替換)功能實(shí)現(xiàn)方法

 更新時(shí)間:2018年04月04日 16:45:27   作者:滅蒙鳥(niǎo)  
本篇文章主要介紹了Angular HMR(熱模塊替換)功能實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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

稍微研究了一下,發(fā)現(xiàn)在angular/cli創(chuàng)建的項(xiàng)目中,實(shí)現(xiàn)這個(gè)不算太難,步驟如下:

1、首先創(chuàng)建一個(gè)src/environments/environment.hmr.ts文件,內(nèi)容如下

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

當(dāng)然,對(duì)應(yīng)的environment.prod.ts和environment.ts需要增加一個(gè)hmr:false.

如果environment.ts里面的hmr設(shè)置為ture,那么ng serve --hmr也有同樣效果。不過(guò)我對(duì)熱替換功能還不是那么相信,重新刷新瀏覽器能保證狀態(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中增加一個(gè)新的命令。(當(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會(huì)替換原始的bootstrap(下面會(huì)看到), 替換后,當(dāng)有新的模塊更新時(shí),hmr會(huì)首先移除掉舊有的模塊,然后接收新的模塊。這些都是發(fā)生在瀏覽器里面。所以頁(yè)面不會(huì)刷新。

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

這里替換就得啟動(dòng)文件,如果設(shè)置為hmr,那么調(diào)用hmrBootStrap來(lái)啟動(dòng)網(wǎng)頁(yè),否則就用過(guò)去的

7、現(xiàn)在運(yùn)行npm run hmr或者ng serve --hmr -e=hmr,就實(shí)現(xiàn)了熱替換功能。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Angular應(yīng)用里環(huán)境變量SERVER_REQUEST_ORIGIN含義解析

    Angular應(yīng)用里環(huán)境變量SERVER_REQUEST_ORIGIN含義解析

    這篇文章主要為大家介紹了Angular應(yīng)用里環(huán)境變量SERVER_REQUEST_ORIGIN的含義解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 深入理解Angular中的依賴注入

    深入理解Angular中的依賴注入

    本篇文章主要介紹了深入理解Angular中的依賴注入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 淺析angularJS中的ui-router和ng-grid模塊

    淺析angularJS中的ui-router和ng-grid模塊

    下面小編就為大家?guī)?lái)一篇淺析angularJS中的ui-router和ng-grid模塊。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • angular組件間通訊的實(shí)現(xiàn)方法示例

    angular組件間通訊的實(shí)現(xiàn)方法示例

    這篇文章主要給大家介紹了關(guān)于angular組件間通訊的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用angular組件具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • angular $watch 一個(gè)變量的變化(實(shí)例講解)

    angular $watch 一個(gè)變量的變化(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇angular $watch 一個(gè)變量的變化(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 詳解AngularJS中$filter過(guò)濾器使用(自定義過(guò)濾器)

    詳解AngularJS中$filter過(guò)濾器使用(自定義過(guò)濾器)

    這篇文章主要介紹了詳解AngularJS中$filter過(guò)濾器使用(自定義過(guò)濾器)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • angular實(shí)現(xiàn)表單驗(yàn)證及提交功能

    angular實(shí)現(xiàn)表單驗(yàn)證及提交功能

    這篇文章主要為大家詳細(xì)介紹了angular實(shí)現(xiàn)表單驗(yàn)證及提交功能的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Angularjs中使用指令綁定點(diǎn)擊事件的方法

    Angularjs中使用指令綁定點(diǎn)擊事件的方法

    本篇文章主要介紹了Angularjs中使用指令綁定點(diǎn)擊事件的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • angular和BootStrap3實(shí)現(xiàn)購(gòu)物車功能

    angular和BootStrap3實(shí)現(xiàn)購(gòu)物車功能

    這篇文章主要為大家詳細(xì)介紹了angular和BootStrap3實(shí)現(xiàn)購(gòu)物車功能的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • AngularJS指令中的綁定策略實(shí)例分析

    AngularJS指令中的綁定策略實(shí)例分析

    這篇文章主要介紹了AngularJS指令中的綁定策略,結(jié)合實(shí)例形式分析了scope綁定策略的分類與具體實(shí)現(xiàn)方法,需要的朋友可以參考下
    2016-12-12

最新評(píng)論