Angular 7 SSR 报错 "ReferenceError: document is not defined" 的原因是 document 对象在服务器端渲染中未定义。
创始人
2024-10-16 20:00:45
0

在服务器端渲染(SSR)中,由于没有浏览器环境,因此没有定义document对象。在Angular中,通常使用document对象来执行DOM操作,但在服务器端渲染时,需要避免直接使用document对象。

解决这个问题的一种方法是使用Angular Universal,它是Angular官方提供的服务器端渲染解决方案。Angular Universal可以在服务器上渲染Angular应用,避免了在服务器端使用浏览器特定的API。

以下是使用Angular Universal解决此问题的示例代码:

1.首先,安装Angular Universal:

ng add @nguniversal/express-engine

2.创建一个Angular Universal的服务:

ng generate universal my-universal-app

3.在app.server.module.ts文件中,使用PlatformServer模块替换BrowserModule模块:

import { NgModule } from '@angular/core';
import { ServerModule, ServerTransferStateModule } from '@angular/platform-server';

import { AppModule } from './app.module';
import { AppComponent } from './app.component';

@NgModule({
  imports: [
    AppModule,
    ServerModule,
    ServerTransferStateModule,
  ],
  bootstrap: [AppComponent],
})
export class AppServerModule {}

4.在main.ts文件中,使用createServerRenderer函数替换原来的platformBrowserDynamic函数:

import { enableProdMode } from '@angular/core';
import { createServerRenderer } from 'aspnet-prerendering';

import { AppServerModule } from './app/app.server.module';

enableProdMode();

export default createServerRenderer(params => {
  const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = (module as any).exports;
  const options = {
    document: params.data.originalHtml,
    url: params.url,
    extraProviders: [
      provideModuleMap(LAZY_MODULE_MAP)
    ]
  };

  return AppServerModuleNgFactory
    .then(factory => factory(options))
    .then(moduleRef => {
      const appRef: ApplicationRef = moduleRef.injector.get(ApplicationRef);
      const state = moduleRef.injector.get(TransferState);
      const stateData = JSON.stringify(state.toJson());
      return {
        html: options.document,
        globals: {
          app: {
            provide: createTransferScript({ AppServerModule, stateData }),
            useFactory: (transferData: any) => transferData,
            deps: [TransferState]
          }
        }
      };
    });
});

通过使用Angular Universal,你可以在服务器端渲染Angular应用,并避免在服务器端使用浏览器特定的API,如document对象。

相关内容

热门资讯

4分钟辅助!河洛杠次怎么提高胜... 4分钟辅助!河洛杠次怎么提高胜率,原来有辅助app(有挂功能)一、河洛杠次怎么提高胜率可以开透视的定...
两分钟辅助!广西八一字牌有挂吗... 两分钟辅助!广西八一字牌有挂吗,确实存在有辅助插件(有挂技巧)小薇(辅助器软件下载)致您一封信;亲爱...
4分钟辅助!传送屋激k万能辅助... 4分钟辅助!传送屋激k万能辅助器app,好像真的有辅助挂(果真有挂)在进入传送屋激k万能辅助器app...
八分钟辅助!四川熊猫辅助软件免... 八分钟辅助!四川熊猫辅助软件免费,一贯是有辅助app(有挂神器)1、点击下载安装,四川熊猫辅助软件免...
八分钟辅助!手游奇迹陕西辅助工... 八分钟辅助!手游奇迹陕西辅助工具,真是存在有辅助神器(揭秘有挂)1、许多玩家不知道手游奇迹陕西辅助工...
第八分钟辅助!湛江吴川0759... 第八分钟辅助!湛江吴川0759作弊,确实真的是有辅助器(揭秘有挂)1、打开软件启动之后找到中间准星的...
第八分钟辅助!湖南赣湘互娱辅助... 第八分钟辅助!湖南赣湘互娱辅助脚本,确实存在有辅助教程(有挂方针)1、起透看视 湖南赣湘互娱辅助脚本...
9分钟辅助!雀神广东麻将推倒胡... 9分钟辅助!雀神广东麻将推倒胡辅助器下载,真是真的有辅助神器(有挂规律)1、让任何用户在无需雀神广东...
第3分钟辅助!川娱竞技有挂透视... 第3分钟辅助!川娱竞技有挂透视脚本,竟然存在有辅助器(有挂教学)1、川娱竞技有挂透视脚本公共底牌简单...
第二分钟辅助!福建兄弟十三水辅... 第二分钟辅助!福建兄弟十三水辅助器,都是真的有辅助教程(今日头条)1、上手简单,内置详细流程视频教学...