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命令来构建和启动

相关内容

热门资讯

黑科技游戏!aapoker软件... 黑科技游戏!aapoker软件app(黑科技ai)固有真的有挂(有挂打法)-哔哩哔哩,支持语音通讯、...
黑科技辅助!德州之星app辅助... 自定义德州之星app辅助系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不...
黑科技真的!aapoker透明... 黑科技真的!aapoker透明挂下载(黑科技)原来是有挂(有挂胜率)-哔哩哔哩;支持2-10人实时对...
黑科技透明挂!红龙扑克有挂么(... 黑科技透明挂!红龙扑克有挂么(透视)真是真的是有挂(有挂自建房)-哔哩哔哩;原来确实真的有挂(需添加...
黑科技能赢!红龙扑克会作假吗(... 这是一款非常优秀的红龙扑克会作假吗 ia辅助检测软件,能够让你了解到红龙扑克会作假吗中牌率当中全部隐...
黑科技脚本!拱趴大菠萝免费辅助... 此外,数据分析德州(拱趴大菠萝免费辅助器)辅助神器app还具备辅助透视行为开挂功能,通过对客户拱趴大...
黑科技透明挂!wpk有辅助挂吗... 这是一款非常优秀的wpk有辅助挂吗 ia辅助检测软件,能够让你了解到wpk有辅助挂吗中牌率当中全部隐...
黑科技能赢!wepokeai代... 黑科技能赢!wepokeai代打逻辑(透明挂)先前是真的有挂(有挂计算器)-哔哩哔哩;建议优先通过w...
黑科技透明挂!德扑牌型胜率计算... 1、黑科技透明挂!德扑牌型胜率计算(辅助挂)起初真的有挂(有挂识别)-哔哩哔哩;详细教程。2、德扑牌...
黑科技能赢!wepoke德州扑... 《黑科技能赢!wepoke德州扑克(ai代打)一向有挂(有挂实锤)-哔哩哔哩》 wepoke德州扑克...