gpt4 book ai didi

angular - HMR 没有使用 Angular CLI 更新 View

转载 作者:太空狗 更新时间:2023-10-29 17:51:17 25 4
gpt4 key购买 nike

我最近将我的 Angular 应用程序更新到了最新版本。经过一夜的 bug 噩梦之后,除了 HMR 之外,我的一切都正常工作了。我非常坚持它。以下是我根据 Angular CLI wiki 上的 HMR 故事进行的配置:

Angular .json

      "build": {
"configurations": {
"hmr": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.hmr.ts"
}
]
}
}
},
"serve": {
"configurations": {
"hmr": {
"hmr": true,
"browserTarget": "appHit:build:hmr"
},
}
},

hmr.js

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(mod => ngModule = mod);
module.hot.dispose(() => {
const appRef: ApplicationRef = ngModule.injector.get(ApplicationRef);
const elements = appRef.components.map(c => c.location.nativeElement);
const makeVisible = createNewHosts(elements);
ngModule.destroy();
makeVisible();
});
};

主要.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('HMR is not enabled for webpack-dev-server!');
console.log('Are you using the --hmr flag for ng serve?');
}
} else {
bootstrap().catch(err => console.log(err));
}

我尝试了以下命令:

ng serve --hmr

ng serve --hmr --configuration hmr

ng serve --configuration hmr

一切都在更改时编译,甚至触发的事件都缓存在浏览器中,但在 HMR 记录以下内容后没有任何反应:

[WDS] App updated. Recompiling...
[WDS] App hot update...

此时我完全迷失了。任何形式的帮助将不胜感激。谢谢

最佳答案

我们遇到了同样的问题。它通过删除与 Webpack 相关的开发依赖项并执行全新的 npm 安装来解决。

rm -R package-lock.json node_modules
npm 缓存清理 --force
npm 我

希望对您有所帮助。

关于angular - HMR 没有使用 Angular CLI 更新 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50810102/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com