Angularuniversal是否可以完全在服务器端渲染?
创始人
2024-10-29 21:01:06
0

是的,可以通过Angular Universal的服务端渲染来完成。以下是一个基本示例:

首先安装Angular Universal:

ng add @nguniversal/express-engine

然后导入ServerModule和ModuleMapLoaderModule:

import { NgModule } from '@angular/core';
import { ServerModule } from '@angular/platform-server';
import { AppModule } from './app.module';
import { AppComponent } from './app.component';
import { ModuleMapLoaderModule } from '@nguniversal/module-map-ngfactory-loader';

在AppModule中,添加ServerModule和ModuleMapLoaderModule:

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

在服务端应用的main.ts中,使用renderModuleFactory函数进行渲染:

import 'zone.js/dist/zone-node';
import { enableProdMode } from '@angular/core';
import { renderModuleFactory } from '@angular/platform-server';
import { AppServerModuleNgFactory } from './src/main.server';

const express = require('express');
const { join } = require('path');

const app = express();

const PORT = process.env.PORT || 4000;
const DIST_FOLDER = join(process.cwd(), 'dist');

app.engine('html', (_, options, callback) => {
  const renderOptions = {
    document: options.req.initialUrl,
    url: options.req.url,
    extraProviders: [
        { provide: 'req', useValue: options.req },
        { provide: 'res', useValue: options.res },
      ],
  };

  renderModuleFactory(AppServerModuleNgFactory, renderOptions)
    .then(html => callback(null, html));
});

app.set('view engine', 'html');
app.set('views', join(DIST_FOLDER, 'browser'));

app.get('*.*', express.static(join(DIST_FOLDER, 'browser')));
app.get('*', (req, res) => {
  res.render('index', { req });
});

app.listen(PORT, () => {
  console.log(`Node server listening on http://localhost:${PORT}`);
});

通过运行npm run build:ssr和npm run serve:ssr命令来构建和启动

相关内容

热门资讯

wpk透视辅助!wPk的确是有... wpk透视辅助!wPk的确是有挂的,wPk一贯真的有挂,玩家教你(有挂脚本);1)wpk辅助挂:进一...
we辅助poker德之星!we... we辅助poker德之星!wepower有辅助软件,WepOke好像真的有挂,攻略方法(有挂解说);...
德州ai机器人!德扑牌力分析软... 德州ai机器人!德扑牌力分析软件,nzt德州本来真的有挂(详细辅助器购买教程)是一款可以让一直输的玩...
wpk发牌逻辑!WPK总是真的... wpk发牌逻辑!WPK总是真的有挂,WpK本来真的有挂,微扑克教程(有挂脚本)1、每一步都需要思考,...
wepower有外 挂!wop... wepower有外 挂!wopoker辅助v3.0,wEpoKe一直真的有挂,曝光教程(有挂规律);...
德州之星辅助!德扑之星软件介绍... 德州之星辅助!德扑之星软件介绍,德扑线上竟然真的有挂(详细AI智能辅助机器人教程)1、快速入门:当你...
wpk德州透视辅助!wpk数据... wpk德州透视辅助!wpk数据抓包(wPk)本来真的有挂-详细透明挂教程;1、每一步都需要思考,不同...
德扑ai助手!德扑之星好牌,菠... 自定义德扑ai助手系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是...
wepoke辅助机器人!wep... wepoke辅助机器人!wepoke黑科技是啥,wepower使用说明书,黑科技教程(有挂攻略);w...
wpk真的有外 挂!wpk被系... wpk真的有外 挂!wpk被系统针对(WPk)果然真的有挂-详细透明挂教程;1、任何wpkai辅助神...