Angular与universal一起渲染页面会导致页面渲染两次。
创始人
2024-10-30 18:30:44
0

解决这个问题的方法是使用Angular的TransferState模块来避免页面渲染两次。TransferState模块允许在服务器和客户端之间传输状态,以便在服务器渲染期间收集数据并在客户端渲染期间重新使用。

以下是一个示例代码,展示了如何使用TransferState模块来解决这个问题:

  1. 在服务器端渲染的主模块文件(通常是main.server.ts)中,导入TransferState模块和相关模块:
import { enableProdMode } from '@angular/core';
import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';
import { ServerModule, ServerTransferStateModule } from '@angular/platform-server';
import { AppModule } from './app/app.module';
import { AppComponent } from './app/app.component';

// Enable production mode
enableProdMode();

// Create an instance of the app module
const app = new AppModule(AppComponent);

// Export a function that returns the server-side rendered HTML
export default function (params: any, url: string): Promise {
  return platformDynamicServer().bootstrapModule(app).then(moduleRef => {
    const state = moduleRef.injector.get(TransferState);
    state.set('REQUEST', url);

    const appRef = moduleRef.injector.get(ApplicationRef);
    const stateTransferService = moduleRef.injector.get(StateTransferService);
    const transferData = stateTransferService.get();

    if (transferData) {
      stateTransferService.inject();
      stateTransferService.set(transferData);
    }

    return appRef.isStable.pipe(
      filter(stable => stable),
      take(1),
      switchMap(() => moduleRef.injector.get(PlatformState).renderToString())
    ).toPromise();
  });
}
  1. 在AppModule中导入TransferState模块,并使用TransferState服务来收集和重新使用数据:
import { NgModule } from '@angular/core';
import { BrowserTransferStateModule, TransferState } from '@angular/platform-browser';
import { AppComponent } from './app.component';

@NgModule({
  imports: [
    BrowserModule.withServerTransition({ appId: 'my-app' }),
    BrowserTransferStateModule,
    // ...
  ],
  declarations: [AppComponent],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule {
  constructor(private transferState: TransferState) {
    const data = this.transferState.get(key, null);
    if (data) {
      // Use the transferred data
    } else {
      // Make HTTP requests to get data
    }
  }
}

通过使用TransferState模块,可以避免Angular与universal一起渲染页面导致页面渲染两次的问题。它允许在服务器端收集数据并在客户端端重新使用,从而提高性能和用户体验。

相关内容

热门资讯

近日!红龙poker有辅助吗(... 近日!红龙poker有辅助吗(透视)新道游辅助软件下载(总是真的有辅助安装)-哔哩哔哩新道游辅助软件...
经调查!破解辅助插件wepok... 经调查!破解辅助插件wepoker(透视)悟空大厅辅助器(果然真的是有辅助辅助器)-哔哩哔哩亲,关键...
据统计!hh poker辅助有... 据统计!hh poker辅助有用吗(透视)创思维辅助器(其实有辅助神器)-哔哩哔哩1、让任何用户在无...
此事备受玩家关注!hhpoke... 此事备受玩家关注!hhpoker有后台操控吗(透视)雀神挂件价格(竟然是有辅助插件)-哔哩哔哩1、雀...
连日来!wepoker辅助器激... 连日来!wepoker辅助器激活码(透视)闲来辅助工具(确实是有辅助工具)-哔哩哔哩1、完成闲来辅助...
透视代打!wepoker底牌透... 透视代打!wepoker底牌透视脚本(透视)潮友会鱼虾蟹怎么发现软件控制(原来存在有辅助下载)-哔哩...
透视模拟器!聚星ai辅助工具激... 透视模拟器!聚星ai辅助工具激活码(透视)微信大a辅助(好像真的是有辅助app)-哔哩哔哩透视模拟器...
透视辅助!wepoker破解工... 透视辅助!wepoker破解工具(透视)潮汕馆透视牌(总是真的是有辅助平台)-哔哩哔哩1、潮汕馆透视...
连日来!德扑之心免费透视(透视... 连日来!德扑之心免费透视(透视)微乐家乡自建房辅助app(果然存在有辅助修改器)-哔哩哔哩1、这是跨...
据统计!impoker辅助(透... 据统计!impoker辅助(透视)新上游通用挂是真的吗(确实是有辅助神器)-哔哩哔哩1、用户打开应用...