AngularUniversal是否可以在响应客户端之前从服务器执行HTTP请求以构建页面?
创始人
2024-10-29 21:01:07
0

可以使用Angular Universal的TransferState模块和HttpClient模块将HTTP请求从服务器转移到客户端。

以下是示例代码:

//app.module.ts

import { BrowserModule, BrowserTransferStateModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { HttpClientModule, HttpClient } from '@angular/common/http'; import { TransferHttpCacheModule } from '@nguniversal/common'; import { AppComponent } from './app.component';

@NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule.withServerTransition({appId: 'my-app'}), HttpClientModule, BrowserTransferStateModule, TransferHttpCacheModule, ], providers: [ HttpClient, ], bootstrap: [AppComponent] }) export class AppModule { }

//app.component.ts

import { Component, OnInit, Inject, PLATFORM_ID } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { isPlatformServer } from '@angular/common'; import { TransferState, makeStateKey } from '@angular/platform-browser';

const SERVER_INIT_KEY = makeStateKey('server-init');

@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent implements OnInit { title = 'my-app'; dataFromServer: any;

constructor( private http: HttpClient, private transferState: TransferState, @Inject(PLATFORM_ID) private platformId: Object ) { }

ngOnInit() { if (isPlatformServer(this.platformId)) { // Server side rendering this.dataFromServer = 'This data came from the server'; this.transferState.set(SERVER_INIT_KEY, true); } else { // Browser rendering const serverInit = this.transferState.get(SERVER_INIT_KEY, false); if (!serverInit) { // This data didn't come from the server, so fetch it this.http.get('/api/data').subscribe(data => { this.dataFromServer = data; }); } else { // This data came from the server this.dataFromServer = this.transferState.get('dataFromServer', null); } } } }

在这个示

相关内容

热门资讯

透视黑科技!奇迹陕西游戏辅助,... 您好:这款奇迹陕西游戏辅助游戏是可以开挂的,确实是有挂的,很多玩家在这款奇迹陕西游戏辅助游戏中打牌都...
透视科技!天天辅助器透视,hh... 天天辅助器透视是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信...
透视系统!奇迹陕西靖边打锅子辅... 透视系统!奇迹陕西靖边打锅子辅助,wpk辅助器是真的吗(辅助挂)详细开挂辅助插件;亲,奇迹陕西靖边打...
透明总结!wepoker轻量版... 透明总结!wepoker轻量版透视系统,sohoopoker辅助(辅助挂)详细开挂辅助脚本您好:we...
透视智能ai!越乡游义乌透视下... 透视智能ai!越乡游义乌透视下载,wepoker俱乐部辅助器(辅助挂)详细开挂辅助工具;无需打开直接...
透视脚本!闲逸辅助正版免费下载... 透视脚本!闲逸辅助正版免费下载,WePoKer辅助器(辅助挂)详细开挂辅助下载;无需打开直接搜索微信...
透视规律!粤友会辅助器下载教程... 您好:这款粤友会辅助器下载教程游戏是可以开挂的,确实是有挂的,很多玩家在这款粤友会辅助器下载教程游戏...
透视中牌率!友间联盟辅助,约局... 透视中牌率!友间联盟辅助,约局吧开挂神器是真的吗(辅助挂)详细开挂辅助插件;无需打开直接搜索薇:13...
透明科技!wepoker插件辅... 透明科技!wepoker插件辅助,wpk俱乐部是做什么的(辅助挂)详细开挂辅助器;无需打开直接搜索微...
透视线上!随意玩房卡辅助,hh... 透视线上!随意玩房卡辅助,hhpoker买挂(辅助挂)详细开挂辅助工具 了解更多开挂安装加(1367...