SSR 服务端渲染

什么是浏览器端渲染(CSR)?

浏览器端渲染是后端提供数据,前端做视图和交互逻辑。页面初始加载的HTML种无内容,需要下载执行JS文件,由浏览器动态生成页面,并通过JS进行页面交互与状态管理。

什么是服务端渲染(SSR)?

页面内容由服务端渲染生成,并返回HTML给浏览器,浏览器只需解析HTML即可。

为什么会出现SSR?

1.解决SEO

(SEO,搜索引擎优化。简单来说就是要让搜索引擎收录你的网页,并让排名靠前一点)
前端项目需要页面加载完成后再去拉取数据进行渲染,大部分搜索引擎或者爬虫无法读取页面内容,特别是SPA项目,每个路由页面更是难以读取。

2.首屏渲染速度

正常情况下要先加载JS,再通过JS取加载数据。所以难以避免出现首屏白屏。
首屏渲染时间对比:

  • SSR:请求发送时间+服务端渲染时间+页面返回时间
  • CSR:请求发送时间+页面返回时间+JS加载时间

缺点

  • 服务器性能
    如果用户规模比较大,SPA本身是一个大型的分布式系统,充分利用用户的设备去运行JS,SSR则是把这些工作包揽到自己到服务器上。所以对需要大量计算且用户量巨大对页面,并不适合。但是SSR特别适合大部分对内容展示页面
  • 开发难度增大
    虽然现在Vue、React都推出了相应都SSR解决方案,但是项目复杂度增加。

SSR框架:

vue:Nuxt.js
React: Next.js

你可能感兴趣的:(SSR 服务端渲染)