Heim > Web-Frontend > js-Tutorial > So implementieren Sie die Angular-HMR-Funktion

So implementieren Sie die Angular-HMR-Funktion

php中世界最好的语言
Freigeben: 2018-05-26 16:38:29
Original
1055 Leute haben es durchsucht

Dieses Mal zeige ich Ihnen, wie Sie die Angular-HMR-Funktion implementieren und welche Vorsichtsmaßnahmen für die Implementierung der Angular-HMR-Funktion gelten. Das Folgende ist ein praktischer Fall, schauen wir uns das an.

Als ein Kollege kürzlich Angular verwendete, hoffte er, eine Funktion wie VUE zu haben, bei der der Browser nach der Änderung des Codes nicht aktualisiert wird und die Seite automatisch aktualisiert entsprechend den geänderten Komponenten . Der Name dieser Funktion ist HMR (Hot Module Replacement).

Nach ein wenig Recherche habe ich festgestellt, dass es nicht allzu schwierig ist, dies in dem von angle/cli erstellten Projekt zu implementieren. Die Schritte sind wie folgt:

Erstellen Sie zuerst eine src/. Umgebungen/environment.hmr. ts Datei, der Inhalt ist wie folgt

export const environment = {
 production: false,
 hmr: true
};
Nach dem Login kopieren

Natürlich müssen die entsprechenden Environment.prod.ts und Environment.ts ein hmr:false hinzufügen.

Wenn Wenn hmr in der Datei „environment.ts“ auf „true“ gesetzt ist, hat ng servo --hmr ebenfalls den gleichen Effekt. Allerdings bin ich nicht so überzeugt von der Hot-Replacement-Funktion, die sicherstellen kann, dass der Status sauberer ist, daher habe ich hmr in Environment.ts auf „false“ gesetzt .angular – Fügen Sie die HMR-Umgebung zur Umgebung der Datei cli.json hinzu, ungefähr wie folgt:

"environments": {
 ...
 "hmr": "environments/environment.hmr.ts",
}
Nach dem Login kopieren

3. Fügen Sie einen neuen Befehl zu den Skripten von package.json hinzu. (Natürlich können Sie ng servo --hmr -e=hmr auch direkt ausführen, ohne es hinzuzufügen, was den gleichen Effekt hat wie das Ausführen von npm run hmr)

"scripts": {
 ...
 "hmr": "ng serve --hmr -e=hmr"
}
Nach dem Login kopieren

4 hmr-Modul, der Befehl lautet wie folgt:

npm install --save-dev @angularclass/hmr
Nach dem Login kopieren

5. Erstellen Sie die Datei srchmr.ts mit folgendem Inhalt:

Dies ist der Schlüssel zum Hot-Replacement (Wie Sie unten sehen werden). Wenn das Modul aktualisiert wird, entfernt HMR zunächst das alte Modul und erhält dann das neue Modul. Dies geschieht alles im Browser. Daher wird die Seite nicht aktualisiert.

6. Aktualisieren Sie die Datei srcmain.ts wie folgt:

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();
}
Nach dem Login kopieren

Der Ersatz hier erfordert die Startdatei. Wenn sie auf hmr eingestellt ist, rufen Sie hmrBootStrap auf, um die Webseite zu starten die Vergangenheit

7. Führen Sie nun npm run hmr oder ng Serve --hmr -e=hmr aus, um die Hot-Replacement-Funktion zu realisieren.

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!

Empfohlene Lektüre:

Komplette gängige JS-Sortieralgorithmen

So verwenden Sie React Native, um eine Floating-Button-Komponente zu erstellen

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Angular-HMR-Funktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage