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

相关内容

热门资讯

透视计算!cloudpoker... 透视计算!cloudpoker作弊(透视)新2025教程(2024已更新)(哔哩哔哩)cloudpo...
透视好牌!aapoker免费透... 透视好牌!aapoker免费透视脚本(透视)辅助(好像是有挂)1、不需要AI权限,帮助你快速的进行a...
透视免费!poker mast... 透视免费!poker master辅助(透视)攻略方法(2023已更新)(哔哩哔哩)1、首先打开po...
透视规律!aapoker怎么控... 透视规律!aapoker怎么控制牌(透视)发牌逻辑(好像真的是有挂)aapoker怎么控制牌辅助器中...
透视插件!来玩app破解版(透... 透视插件!来玩app破解版(透视)2025版教程(2020已更新)(哔哩哔哩)1、很好的工具软件,可...
透视线上!aapoker透视脚... 透视线上!aapoker透视脚本入口(透视)透视软件(一直有挂)亲,关键说明,aapoker透视脚本...
透视好友房!拱趴大菠萝有什么挂... 透视好友房!拱趴大菠萝有什么挂(透视)解说技巧(2021已更新)(哔哩哔哩);1)拱趴大菠萝有什么挂...
透视了解!aapoker脚本(... 透视了解!aapoker脚本(透视)辅助插件工具(切实是有挂);1)aapoker脚本辅助挂:进一步...
透视ai代打!哈糖大菠萝挂(透... 透视ai代打!哈糖大菠萝挂(透视)攻略教程(2021已更新)(哔哩哔哩)1、点击下载安装,哈糖大菠萝...
透视规律!aapoker辅助器... 透视规律!aapoker辅助器怎么用(透视)真的假的(一直有挂)1、全新机制【aapoker辅助器怎...