这个错误通常是因为Angular在服务端渲染期间尝试了在没有DOM环境的情况下访问document变量。通常情况下,这个错误可以通过在适当的位置使用适当的逻辑来避免或解决。以下是几种实现的方法:
import { PLATFORM_ID, APP_ID, Inject, NgModule } from '@angular/core'; import { isPlatformBrowser } from '@angular/common'; import { BrowserModule, ɵDOMSharedStylesHost } from '@angular/platform-browser';
@NgModule({ imports: [BrowserModule], providers: [ɵDOMSharedStylesHost, { provide: APP_ID, useValue: 'app' }, { provide: PLATFORM_ID, useFactory: getPlatformId, deps: [ɵDOMSharedStylesHost] }, { provide: 'canUseDOM', useFactory: () => !!window, }, { provide: DOCUMENT, useFactory: (domService: ɵDOMSharedStylesHost, platformId: Object) => { if (isPlatformBrowser(platformId)) { return document; } else { return domService.getDocument(); } }, deps: [ɵDOMSharedStylesHost, PLATFORM_ID], }, ], bootstrap: [AppComponent], declarations: [AppComponent], }) export class AppModule {}
if (isPlatformBrowser(this.platformId)) { // 在这里放在运行期间需要在客户端环境下运行的代码。 }
import { PLATFORM_ID, APP_ID, Inject, NgModule } from '@angular/core'; import { isPlatformBrowser }