首页 技术 正文
技术 2022年11月14日
0 收藏 455 点赞 2,808 浏览 2457 个字

其他章节请看:

前端学习 node 快速入门 系列

服务端渲染

简易版 Apache一文中,我们用 node 做了一个简单的服务器,能提供静态资源访问的能力。

对于真正的网站,页面中的数据应该来自服务器(服务器查询数据库),我们来模拟一下。请看示例:

- demo
- node_modules // 安装 art-template 后自动生成
- public
- lib
- art-template // 将 node_modules/art-template 拷贝过来即可
- view
- client-render.html // 页面内容采用客户端渲染
- server-render.html // 页面内容采用服务端渲染
- index.js // 入口文件
- package.json // 只依赖于 art-template

:如果不明白 node_modules、package.json,可以看我的另外一篇文章(npm

client-render.html:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src='/public/lib/art-template/lib/template-web.js'></script>
</head>
<body>
<h2>客户端渲染</h2>
<div id="content"></div>
<script id="test" type="text/html">
<p>{{title}}</p>
<ul>
{{each list as value i}}
<li>索引 {{i + 1}} :{{value}}</li>
{{/each}}
</ul>
</script>
<script>
var data = {
title: '标签',
list: ['文艺', '博客', '摄影']
};
// 前端使用模板引擎
var html = template('test', data);
document.getElementById('content').innerHTML = html;
</script>
</body>
</html>

server-render.html:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<h2>服务端渲染</h2> <p>{{title}}</p>
<ul>
{{each list as value i}}
<li>索引 {{i + 1}} :{{value}}</li>
{{/each}}
</ul>
</body>
</html>

index.js:

const http = require('http')
const fs = require('fs')
const template = require('art-template')
const server = http.createServer()const requestListener = (req, res) => {
let url = req.url
// 客户端渲染
if(url.endsWith('client-render.html')){
fs.readFile('./public/view/' + url, (err, data) => {
if (err) throw err;
res.end(data)
});
return
}
// 服务端渲染
if(url.endsWith('server-render.html')){
fs.readFile('./public/view/' + url, (err, data) => {
if (err) throw err;
// 服务端使用模板引擎
const ret = template.render(data.toString(), {
title: '标签',
list: ['文艺', '博客', '摄影']
});
res.end(ret)
});
return
}
fs.readFile('.' + url, (err, data) => {
if (err) {
res.writeHead(404, {'Content-type':'text/html;charset=utf8'})
res.end('没有找到对应的资源')
}
res.end(data)
})
}server.on('request', requestListener)
server.listen('3000', () => {
console.log('服务器已启动')
})

启动服务器:

$ node index

访问:

1. 浏览器输入 http://localhost:3000/server-render.html页面显示:<是有样式的>
服务端渲染
标签索引 1 :文艺
索引 2 :博客
索引 3 :摄影2. 浏览器输入 http://localhost:3000/client-render.html
页面显示:<与 server-render.html 相同>

虽然两个页面看起来相同,但一个是客户端渲染,一个是服务端渲染

Tip:模板引擎是为了使用户界面和业务数据分离而产生的,它可以生成特定格式的文档。模板引擎最初出现在服务端。

这里使用的模板引擎是 art-template。模板引擎应用在客户端就是客户端渲染;模板引擎应用在服务端就是服务端渲染。更直观的区分,如果源码(浏览器快捷键:ctrl+u)中可以找到前端页面的文字,则说明是服务端渲染,否则是客户端渲染。

:网站通常既有客户端渲染,也有服务端渲染。例如当当网、京东这类电商网站,商品通常使用服务端渲染,因为商品需要被搜索引擎看见;而评论、试读则会使用客户端渲染。

其他章节请看:

前端学习 node 快速入门 系列

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,997
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,511
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,356
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,139
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848