HMR正在追加而不是替换

Dan*_*iel 7 webpack material-design webpack-hmr angular

这是我对页面的初始加载:

在此输入图像描述

在改变一些文本后,HMR会被激活,但是附加 DOM而不是替换它:

在此输入图像描述

有没有人知道什么可能导致这个问题?控制台上没有错误.

更新:

我在命令行中使用了带有角度模板的ASP.NET Core.此模板使用bootstrapjquery.我想删除这两个组件,因此我想使用材料

Dan*_*iel 5

我想我找到了答案:

我想在boot.browser.ts中摆脱bootstrapjquery.所以我删除了一些引用bootstrap的行:

import 'reflect-metadata';
import 'zone.js';
// removed this line
// import 'bootstrap';
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module.browser';
Run Code Online (Sandbox Code Playgroud)

然后我在这个块看到了错误:

if (module.hot) {
    module.hot.accept();
    module.hot.dispose(() => {
        // Before restarting the app, we create a new root element and dispose the old one
        const oldRootElem = document.querySelector('app');
        const newRootElem = document.createElement('app');
        oldRootElem!.parentNode!.insertBefore(newRootElem, oldRootElem);
        modulePromise.then(appModule => appModule.destroy());
    });
}
Run Code Online (Sandbox Code Playgroud)

在评论这些行后,最终结果是:

import 'reflect-metadata';
import 'zone.js';
import 'bootstrap';
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module.browser';

if (module.hot) {
    module.hot.accept();
    module.hot.dispose(() => {
    });
} else {
    enableProdMode();
}

// Note: @ng-tools/webpack looks for the following expression when performing production
// builds. Don't change how this line looks, otherwise you may break tree-shaking.
const modulePromise = platformBrowserDynamic().bootstrapModule(AppModule);
Run Code Online (Sandbox Code Playgroud)