通过Angular CLI 1.6 加入 Angular Universal 服务端渲染功能

angular CLI 1.6内置了 Angular Universal 服务端渲染。解放webpack配置的痛苦。

新建项目

ng new angulrUniversal
cd angulrUniversal
复制代码

加入Angular Universal

ng g universal universal
npm i
复制代码

有兴趣的可以研究下改的什么,建议瞅瞅

然后修改下package.json的build命令

"build": "ng build --prod && ng build --prod --app universal --output-hashing=none",
复制代码

然后打个包

npm run build
复制代码

安装 Angular 官方提供的 Express 引擎

npm i express @nguniversal/express-engine
复制代码

建立server端

新建个server.js

'use strict';

/* Node 专的 Zone.js */
require('zone.js/dist/zone-node');

const express = require('express');
const ngUniversal = require('@nguniversal/express-engine');

/* 从这里载入ssr之后的bundle */
const appServer = require('./dist-server/main.bundle');

/* 主要的服务器渲染函数 */
function angularRouter(req, res) {

  /* Server-side rendering */
   res.render('index', { req, res });

}

const app = express();

/*处理 HTTP 要求 */
app.get('/', angularRouter);

/* 处理静态文件 */
app.use(express.static(`${__dirname}/dist`));

/* 设定 Angular Express 引擎 */
app.engine('html', ngUniversal.ngExpressEngine({
   bootstrap: appServer.AppServerModuleNgFactory
})); 
app.set('view engine', 'html');
app.set('views', 'dist');

/* 将所有其他 HTTP 请求都转給 angularRouter 处理 */
app.get('*', angularRouter);

/* 监听 Port 4200 */
app.listen(4200, () => {
   console.log(`Listening on http://localhost:4200`); 
});
复制代码

启动

node server.js
复制代码

打开http://localhost:4200 OK完工

github:https://github.com/ShaofeiZi/angulrUniversal

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值