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

相关内容

热门资讯

透视存在!wepoker透视脚... 透视存在!wepoker透视脚本苹果版,wepoker辅助脚本,黑科技教程(原本是有挂);wepok...
透视模拟器!aapoker辅助... 透视模拟器!aapoker辅助功能,wepoker正确养号方法,高科技教程(从前有挂)1、这是跨平台...
透视神器!aapoker辅助插... 透视神器!aapoker辅助插件工具,aapoker透视脚本,透明教程(先前真的有挂)是一款可以让一...
透视中牌率!aapoker脚本... 透视中牌率!aapoker脚本怎么用,hhpoker开挂教程,微扑克教程(总是是真的有挂);(需添加...
透视ai代打!德普之星怎么作弊... 透视ai代打!德普之星怎么作弊,wepokerplus开挂,切实教程(原来真的有挂);实战中需综合运...
透视软件!德普之星透视辅助插件... 1、透视软件!德普之星透视辅助插件,哈糖大菠萝攻略,AI教程(都是真的是有挂);详细教程。2、德普之...
透视好友!wpk辅助器是真的吗... 透视好友!wpk辅助器是真的吗,wepoker黑侠辅助器,大神讲解(果然是真的有挂)是一款可以让一直...
透视规律!wepoker底牌透... 透视规律!wepoker底牌透视脚本app,wepoker透视脚本是什么,必备教程(最初真的有挂);...
透视真的!wepoker透视脚... 透视真的!wepoker透视脚本网页,wpk作弊最怕三个东西,细节方法(其实是有挂)关于wepoke...
透视代打!德普之星透视辅助io... 1、透视代打!德普之星透视辅助ios,pokermaster修改器,曝光教程(都是有挂)。2、德普之...