首先从概念上区分,服务器渲染(Server-side Rendering,简称 SSR)和客户端渲染(Client-side Rendering,简称 CSR)主要的区别在于页面的渲染地点不同:
服务器渲染,即 SSR,是在服务器端将数据和模板进行组装,渲染成最终的HTML页面,然后返回给客户端的浏览器,实际上用户第一次打开页面时看到的就是最终渲染的结果。
客户端渲染,即 CSR,初始时服务器返回一个基本的HTML框架和JavaScript文件,数据是通过AJAX或Fetch等技术请求获得的,然后在客户端进行页面的渲染。
他们各自有其优点和缺点:
SSR 的优点主要体现在:
SSR 的缺点:
CSR 的优点:
CSR 的缺点:
Next.js 和 Nuxt.js 等框架提供了一种称为同构渲染(Universal Rendering)或预渲染(Prerendering)的模式,这种模式结合了SSR和CSR两种渲染方式,兼顾了他们的优点。
Next.js 是React的服务端渲染框架,Nuxt.js 是Vue的服务端渲染框架。他们首次渲染在服务器端完成(SSR),能够使用户快速看到页面内容,有利于SEO。之后的页面交互和切换则在客户端完成(CSR),提高了页面响应速度和用户体验,减少了服务器压力。
1、服务器渲染(SSR)
在以下的服务器渲染的示例中,服务器会将数据 "Hello, World!" 嵌入到 HTML 中,并将其发送到客户端。
const express = require('express'); const app = express(); app.get('/', (req, res) => { const response = ` Hello, World!
`; res.send(response); }); app.listen(3000, () => console.log('Server is running on port 3000')); 2、客户端渲染(CSR)
在以下的客户端渲染的示例中,实际上服务器仅仅发送了一个空白的 HTML 页面和一个 JavaScript 文件。这个 JavaScript 文件会在客户端运行,获取数据,并更新 HTML。
服务器端代码:
const express = require('express'); const app = express(); app.get('/', (req, res) => { const response = ` `; res.send(response); }); app.get('/script.js', (req, res) => { const script = ` window.onload = function() { document.getElementById('app').innerHTML = 'Hello, World!
'; }; `; res.send(script); }); app.listen(3000, () => console.log('Server is running on port 3000'));
上一篇:SMTP服务器、Mailu部署、Java实现邮件发送
下一篇:由于生成一个完整的游戏商城代码涉及很多方面(如后端服务器、数据库、前端页面等),这里我会为你提供简化的示例代码,分别用Python(Flask框架用于后端)、JavaScript(Node.js和Ex