Home > Web Front-end > JS Tutorial > What are the implementation methods of hot module replacement?

What are the implementation methods of hot module replacement?

php中世界最好的语言
Release: 2018-05-02 11:05:00
Original
1724 people have browsed it

This time I will bring you some implementation methods of hot module replacement, and what are the precautions for hot module replacement. The following is a practical case, let’s take a look.

After a little research, I found that it is not too difficult to implement this in the project created by angular/cli. The steps are as follows:

1. First create a src/environments/environment.hmr. ts file, the content is as follows

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

Of course, the corresponding environment.prod.ts and environment.ts need to add an hmr:false.

If hmr in environment.ts is set to true, then ng serve --hmr also has the same effect. However, I am not so convinced about the hot replacement function. Refreshing the browser can ensure that the status is cleaner, so let hmr in environment.ts be false.

2. In .angular Add the hmr environment to the environment of the -cli.json file, roughly as follows:

"environments": {
 ...
 "hmr": "environments/environment.hmr.ts",
}
Copy after login

3. Add a new command to the scripts of package.json. (Of course, you can also run ng serve --hmr -e=hmr directly without adding it, which has the same effect as running npm run hmr)

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

4, Install the hmr module, the command is as follows:

npm install --save-dev @angularclass/hmr
Copy after login

5. Create the src\hmr.ts file with the following content:

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

This is the key to hot replacement. hmrBootstrap will replace the original bootstrap (as you will see below). After replacement, when there is When the new module is updated, hmr will first remove the old module and then receive the new module. These all happen in the browser. So the page won't refresh.

6. Update the src\main.ts file as follows:

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

The replacement here requires the startup file. If it is set to hmr, then call hmrBootStrap to start the web page, otherwise use the past

7. Now run npm run hmr or ng serve --hmr -e=hmr to realize the hot replacement function.

I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!

Recommended reading:

Angular5 Add style class step instructions to component tags

How to use websocket in nodejs (with code )

How to get the largest element in a Number type array

The above is the detailed content of What are the implementation methods of hot module replacement?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template