前几天在知乎看到了这个问题,刚好前阵子做过,就回答了一下。下面的是原回答。

大厂技术  高级前端  Node进阶

点击上方 程序员成长指北,关注公众号

回复1,加入高级Node交流群

前言

前阵子有搞了 React 服务端渲染的项目,是否应该用这个主要还是看场景吧。

比较适用于大家常说的 SEO 和首屏渲染这些,一般都是 toc 的业务才会需要用到。

同构

现代框架的服务端渲染和 jsp、php 这些还是有不少区别的。因为 nextjs 和 nuxtjs 这种不仅仅是服务端渲染,它们还是同构框架。

什么是同构呢?就是一份代码既可以跑在浏览器端,也可以跑在服务端。这得益于 NodeJS 在服务端的流行。

传统 jsp、php、django 这些服务端渲染框架都是返回 html 字符串,类似于传统的 MPA 多页面模式。所以切换页面的时候就会刷新,重新请求 css 和 js 文件,用户体验比较差。

而现在流行的前端开发模式都是 SPA 单页面,基于 H5 的 History 来实现切换页面无刷新,这样可以带来更好的用户体验。

所以 nextjs 和 nuxtjs 不仅支持服务端渲染,还支持 SPA,常用的是对首页进行服务端渲染,其他页面依然保持 SPA 的无刷新访问模式。

我们这边就有使用 Django 来编写的页面,维护起来很痛苦。因为无法说清楚哪些是前端负责的,哪些是后端负责的。所以为了维护这个,前端和后端都去要学习 Python 和 Django,大大提高了维护成本。

实际应用场景的话,我们这里有几种场景就比较适合用服务端渲染。

支持 Post 请求

一个是重构的 h5 页面,项目以前是新加坡团队用 Python + Django 写的,所以有些页面是第三方网站 Post 提交表单打开的。

我们重构后的 H5 页面都挂在腾讯云 CDN 上面,不支持用 Post 打开的。为什么不改成 Get 呢?因为这是以前他们协定的,然后银行都是爸爸,他们不会为了我们去改协议的。

页面功能都是比较简单的,所以为了赶上重构的时间线,当时旁边的小伙伴用 Express + EJS 实现了一版,只支持 ES5 的语法。

后续需求经历几次变更,想在原来的页面上加功能都比较麻烦。比如我想实现 JS Bridge,我只能用 microbundle 把现有的 npm 包打成一个 umd 文件,然后用 script 标签引入。

动态渲染标题

前阵子遇到了另一个需求,我需要为多家银行实现同样的 H5 页面,功能基本上都是一样的,但 App 头部需要展示不同银行的名字。

在我们 AirPay App 里面,客户端在打开 webview 的时候会去读取我们 HTML 里面的 title,将其设置为原生头部的标题。

如果我在代码里面使用 document.title 的方式动态设置就不会生效,只能通过 JS Bridge 来动态设置头部。

但这个页面不仅会提供给 AirPay 使用,还会提供給 Shopee 使用,需要兼容两套 JS Bridge,有点儿得不偿失。

但如果使用服务端直出的形式,就可以在服务端直接判断好需要渲染的标题,设置到 HTML 的 title 里面。这就是另一种适合的业务场景了。

所以在之前项目基础上添加了 React 服务端渲染的功能,支持用 React 开发同构应用。这里也没有用 Next,只是自己实现的一套同构。

大致实现思路是用 isomorphic-style-loader 和 universal-router 来处理样式和路由的同构,服务端获取到数据后输出到 window._INITIAL_STATE__ 里面,在浏览器获取这个初始化数据实现数据同构的。

同时也保留了原来的 EJS 模板,都是基于 Express 路由分发的,既可以渲染用 EJS 渲染,也可以用 React 服务端直出。

一期的这个页面是挂在腾讯云 CDN 上面的,二期使用了服务端渲染,可以明显感觉到加载速度变快了很多,毕竟以前还是会展示一个 loading 图。

在进程守护方面,整个部门的 Node 服务都是用大佬写的 Node Agent 来做,也经受住了各种大促的考验。

缺点

当然了,服务端渲染也不应该滥用。

比如我们的内部后台管理系统就上了 Nuxt,现在每次本地构建要花10分钟,非常影响开发效率。

Nuxt 功能还是非常强大的,比如会根据路由动态拆分构建文件、鼠标放到 Nuxt-link 路由组件上面就会预加载 JS 文件等等。

但实际上带来的收益几乎为零,因为我们不需要 SEO,也不需要提高首屏加载速度。

几乎组里面每个人都有尝试用各种手段去优化构建,但效果不是很明显。直到最近开始做微前端拆分,才曲线解决这个问题。

除此之外,服务端渲染在写法上也和客户端渲染有一些区别,容易导致 bug。

比如下面在 Vuex 的 state 文件里面的这段代码:

const date = moment().format('YYYY-MM-DD')export default () => ({date
})

打开页面的时候,时间应该展示的是今天。哪怕页面放置刚好跨天了,打开再刷新也应该是当天时间。

但在 Nuxt 里面,这个展示的日期就是你服务启动那天的日期,不管你怎么刷新,它永远不会变化。

因为 Nuxt 初始化的时候会把这些数据存到 store 里面,后续再怎么刷新,这个文件也不会在服务端重新加载,因为模块会被 Node 缓存起来,所以日期就不会更新。

但在客户端渲染里面,由于页面刷新会导致浏览器端重新加载 JS 文件,这个日期也会重新计算。

Node 社群

我组建了一个氛围特别好的 Node.js 社群,里面有很多 Node.js小伙伴,如果你对Node.js学习感兴趣的话(后续有计划也可以),我们可以一起进行Node.js相关的交流、学习、共建。下方加 考拉 好友回复「Node」即可。

 “分享、点赞、在看” 支持一波 

有必要使用服务器端渲染(SSR)吗?相关推荐

  1. 大前端学习笔记 -- 搭建自己的服务器端渲染 (SSR)

    搭建自己的服务器端渲染 (SSR) 一.渲染一个Vue实例 mkdir vue-ssr cd vue-ssr npm init -y npm i vue vue-server-renderder se ...

  2. 客户端渲染CSR、服务器端渲染SSR、预渲染Prerendering

    什么是客户端渲染 CSR 在进行SPA(单页面应用)开发时,大多数都会选择Vue.js.默认情况下,会生成vue组件,输出到浏览器,进行生成 DOM 和操作 DOM.使用vue.js开发的项目在浏览器 ...

  3. 1. 服务器端渲染(SSR)简介

    1. 服务器端渲染(SSR)简介 1.1 什么是服务器端渲染(SSR)? Vue.js 是构建客户端应用程序的框架 默认情况下浏览器输出Vue组件,生成DOM并操作DOM 服务器端渲染则是服务器端生成 ...

  4. 服务器端渲染 (SSR)

    什么是服务器端渲染 (SSR)? 客户端渲染:使用 JavaScript 框架进行页面渲染 服务端渲染:服务端将HTML文本组装好,并返回给浏览器,这个HTML文本被浏览器解析之后,不需要经过 Jav ...

  5. SAP Spartacus 手动开启服务器端渲染 (SSR) 所必须的步骤

    使用服务器端渲染,我们可以保证搜索引擎,与浏览器的Javascript禁用,或没有JavaScript的浏览器仍然可以访问我们的网站内容. https://b2bspastore.cg79x9wuu9 ...

  6. 为什么使用服务器端渲染 (SSR)?

    什么是 SSR SSR 顾名思义就是 Server-Side Render, 即服务端渲染.原理很简单,就是服务端直接渲染出 HTML 字符串模板,浏览器可以直接解析该字符串模版显示页面,因此首屏的内 ...

  7. linux ssr客户端 npmjs,umijs使用服务器端渲染ssr

    server.js demo 文章已更新,请看下面更新之后的内容 使用官网上教程中的代码有点问题,自己参照实例改了下,修改了个express的ssr server.如果使用的话注意把其中dist改成你 ...

  8. 关于 SAP Spartacus 服务器端渲染 SSR 无法使用窗口宽度以进行自适应设计的问题

    Storefront 的屏幕布局由可配置的断点(configurable breakpoints)驱动.断点具有可配置的屏幕尺寸(即 < 576px),并且关联的屏幕名称可用于进一步定义布局. ...

  9. 手动安装 SAP Spartacus 3.3.0版本并启用服务器端渲染 SSR

    使用 ng new jerryssr 创建一个空的 Angular 项目: 确保项目创建成功. ng add @spartacus/schematics@latest --baseUrl https: ...

  10. 关于自定义的登录机制在SAP Spartacus服务器端渲染(SSR)实施过程中遇到的问题

    问题背景 某客户使用了第三方的Authentication service来实现Spartacus用户的登录机制: In our project we have integration with MD ...

最新文章

  1. php 效率最高的递归,PHP 递归效率分析_PHP教程 - microtime
  2. 同步设备IO与异步设备IO
  3. 空间直角坐标转换之仿射变换(转)
  4. vue2 关于开发插件的几点思考
  5. keil接收别人发的工程打不开_STM32工程模板建立之 KEIL 开发平台设置(一)
  6. (48)VHDL实现8位奇偶校验电路(process语句语句)
  7. OpenCV_cv::Mat初始化
  8. 词根词缀的实践应用 - 词根词缀词典墨墨详细使用
  9. php漂浮广告代码,JS实现网站悬浮广告的代码
  10. Android实战【仿探探陌生社交APP】
  11. Android系统 GPIO状态查询
  12. 支付宝-支付API(电脑网站支付)
  13. 【ICML 2020联邦学习论文解读】SCAFFOLD: Stochastic Controlled Averaging for Federated Learning
  14. 企查查的批量公司查找
  15. 面向对象之多态以及进阶
  16. SpringBoot关闭druid的页面和添加密码验证
  17. 我的世界 为何用java开发?
  18. 一种简单的生成伪随机数的方法
  19. 股票 价格 定价 资料收集
  20. 市场调研报告-全球与中国溶剂净化器市场现状及未来发展趋势

热门文章

  1. 香港中文大学深圳(CUHKSZ)2020fall数据科学硕士申请及笔面经
  2. CPU占用高,IOW过高,KSWAP0
  3. 函数的四种特性——有界性 单调性 奇偶性 周期性
  4. 解决小程序页面路径最多只能十层限制
  5. 基于MATLAB的数字图像处理仿真软件
  6. Xshell7家庭和教育版去除免费许可证弹窗
  7. 先验条件、后验条件、不变条件
  8. Excel-函数-拆分和组合函数
  9. vue编写坐标系以及echarts编写坐标系、highcharts编写坐标系(包含圆形间隔)
  10. Centos 开机启动卡住