在网上查找了很久的前端渲染和后端渲染的区别,最后总算在知乎上看到了一个比较清楚的解释,感谢万分!
作者:iakul
链接:https://www.zhihu.com/question/28725977/answer/42077482
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

后端渲染(SSR、服务端渲染)
后端渲染HTML的情况下,浏览器会直接接收到经过服务器计算之后的呈现给用户的最终的HTML字符串,这里的计算就是服务器经过解析存放在服务器端的模板文件来完成的,在这种情况下,浏览器只进行了HTML的解析,以及通过操作系统提供的操纵显示器显示内容的系统调用在显示器上把HTML所代表的图像显示给用户。

前端渲染(SPA、单页面应用)
前端渲染就是指浏览器会从后端得到一些信息,这些信息或许是适用于题主所说的angularjs的模板文件,亦或是JSON等各种数据交换格式所包装的数据,甚至是直接的合法的HTML字符串。这些形式都不重要,重要的是,将这些信息组织排列形成最终可读的HTML字符串是由浏览器来完成的,在形成了HTML字符串之后,再进行显示。
题主所提到的几个技术,我认为模板这个词语并不能用来区分这些技术的本质,模板只是一种提供给程序来解析的一种语法,换句话说,模板是用于从数据(变量)到实际的视觉表现(HTML代码)这项工作的一种实现手段,而这种手段不论在前端还是后端都有应用。
以下为本人自己的想法:在性能上,我认为后端渲染最终会被前端渲染,因为后端渲染将所有的HTML生成集中在了一个服务器上,而前端渲染将这部分工作分发到各个终端上。另外,对于开发而言,这样能够避免后端开发人员过多的编写HTML代码,后端开发人员只需和前端开发事先商定好数据格式,后端就只需将数据生成,用数据交换格式包装,再发送出去就可以了,这样能够使开发人员之间的分工更加明确。
再附上稀土掘金上的一段理解:

SEO
很重要,所以要普及。
SEO: 搜索引擎优化(Search Engine Optimization),它是指通过站内优化,如:网站结构调整、网站内容建设、网站代码优化以及站外优化等方法,来进行搜索引擎优化。
简单说: 通过各种技术(手段)来确保,你的Web内容被搜素引擎最大化收录,最大化提高权重,带来更多流量。
常见关键词:白帽、黑帽、SEM、Backlink、Linkbait、PageRank、Keyword Stuffing…,总之都围绕着一个核心:SEO;流量是变现的快车道,SEO是低成本获取流量的最佳方法。

SPA
SPA:单页Web应用(single page web application,SPA),就是只有一张Web页面的应用,是加载单个HTML 页面并在用户与应用程序交互时动态更新该页面的Web应用程序。
简单说: Web不再是一张张页面,而是一个整体的应用,一个由路由系统、数据系统、页面(组件)系统…组成的应用程序,其中路由系统是非必须的。
大部分的Vue项目,本质是SPA应用,Angular.js、Angular、Vue、React…还有最早的"Pjax"均如此。
SPA时代,主要是在Web端使用了history或hash(主要是为了低版本浏览器的兼容)API,在首次请求经服务端路由输出整个应用程序后,接下来的路由都由前端掌控了,前端通过路由作为中心枢纽控制一系列页面(组件)的渲染加载和数据交互。
而上面所述的各类框架则是将以:路由、数据、视图为基本结构进行的规范化的封装。
最早的SPA应用,由Gmail、Google Docs、Twitter等大厂产品实践布道,广泛用于对SEO要求不高的场景中。

SSR
SSR: 服务端渲染(Server Side Render),即:网页是通过服务端渲染生成后输出给客户端。
在SPA之前的时代,我们的Web架构大都是SSR,如:Wordpress(PHP)、JSP技术、JavaWeb…或者DEDECMS、Discuz!等这些程序都是传统典型的SSR架构,
即:服务端取出数据和模板组合生成html输出给前端,前端发生请求时,重新向服务端请求html资源,路由也由服务端来控制。
其次,有个概念叫预渲染(Prerendering)。
如果你只是用服务端渲染来改善一个少数的营销页面(如 首页,关于,联系 等等)的SEO,那你可以用预渲染来实现。
预渲染不像服务器渲染那样即时编译HTML,它只在构建时为了特定的路由生成特定的几个静态页面,等于我们可以通过webpack插件将一些特定页面组件build时就编译为html文件,直接以静态资源的形式输出给搜索引擎。
但实际的商业应用中,大部分时候我们需要的是即时渲染,这也是我们今天讨论的主题。

Why
为什么要SSR,为了体验,还有SEO。
首先,用户可能在网络比较慢的情况下从远处访问网站 - 或者通过比较差的带宽。 这些情况下,尽量减少页面请求数量,来保证用户尽快看到基本的内容。
可以用Webpack的代码拆分避免强制用户下载整个单页面应用,但是,这样也远没有下载个单独的预先渲染过的HTML文件性能高。
对于世界上的一些地区人,可能只能用1998年产的电脑访问互联网的方式使用计算机。
而Vue只能运行在IE9以上的浏览器,你可能也想为那些老式浏览器提供基础内容 - 或者是在命令行中使用 Lynx的时髦的黑客。
在大部分的商业应用中,我们有SEO的需求,我们需要搜索引擎更多地抓取到我们的内容,更详细地认识到我们的网页结构,而不是仅对首页或特定静态页进行索引,这是SSR最重要的意义。
简单说就是,我们需要搜素引擎看到这样的代码:

而不是这样的代码:

且,我们还需要在SSR的基础上实现SPA,即:首屏渲染。
基本流程是:
在浏览器第一次访问某个URI资源的时候(首屏),Web服务器根据路由拿到对应数据渲染并输出,且输出的数据中包含两部分:

路由页对应的页面及已渲染好的数据
完整的SPA程序代码

在客户端首屏渲染完成之后,此时我们看到的其实已经是一个和之前的SPA相差无几的应用程序了,接下来我们进行的任何操作都只是客户端的应用进行交互,
页面/组件由Web端渲染,路由也由浏览器控制,用户只需要和当前浏览器内的应用打交道就可以了。
之前在各大SPA框架还未正式官方支持SSR时,有一些第三方的解决方案,如:prerender.io,
它们做的事情就是建立HTTP一个中间层,在判断到访问来源是蜘蛛时,输出已缓存好的html数据,此数据若不存在,则调用第三方服务对html进行缓存,往复进行。
另一方法是自行构建蜘蛛渲染逻辑,当识别UA为搜索引擎时,拿服务端已准备好的模板和数据进行渲染输出html数据,反之,则输出SPA应用代码;
我当时也考虑过此方法,但有很多弊端,如:
需要针对蜘蛛编写一套独立的渲染模板,因为大部分情况下SPA的代码是没法直接在服务端使用的
搜索引擎若检测到蜘蛛抓取数据和真实访问数据不一致,会做降权惩罚,也就意味着渲染模板还必须和SPA预期输出一模一样
所以,最好的方法是SPA能和服务端使用同一套模板,且使用同一个服务端逻辑分支,再简单说:最好Vue、Ng2…能直接在服务端跑起来。
于是,陆续诞生了基于React的Next.js、基于Vue的Nuxt.js、Ng2诞生之日便支持。
没错,Nuxt.js就是今天的主角。
转载自https://juejin.im/post/58ff960ba22b9d0065b722cd

作者:牧码人小鹏
链接:https://www.jianshu.com/p/14c3c4f61d90
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

web前端渲染和后端渲染(web front-end and back-end rendering)相关推荐

  1. 面试须知的前端渲染和后端渲染

    在网上查找了很久的前端渲染和后端渲染的区别,最后总算在知乎上看到了一个比较清楚的解释,感谢万分! 作者:iakul 链接:https://www.zhihu.com/question/28725977 ...

  2. 前端渲染与后端渲染的区别

    前端渲染: 指的是后端返回JSON数据,前端利用预先写的html模板,循环读取JSON数据,拼接字符串(es6的模板字符串特性大大减少了拼接字符串的的成本),并插入页面. 好处:网络传输数据量小.不占 ...

  3. 前端渲染与后端渲染之间的区别?

    前端没兴起之前,网页的展示大都是后端渲染,也就是服务器渲染. 随着前端行业的发展,前端的工作越来越精细.前后端开始分离,前端只关注ui渲染.后端只提供数据和进行逻辑处理. 简单的解释,前端写好html ...

  4. web前端和Java后端有什么区别?

    很多想要学习web前端和Java的人,总是比较纠结自己要学习你那个,web前端和Java要了解web前端和Java的区别,就必须搞懂他们都是什么,干什么的. 要搞懂区别,我们首先要知道他们是什么. W ...

  5. 零基础带你飞web前端教程带你探究web前端趋势

    web前端教程带你探究web前端趋势,IT行业发展迅速,瞬息万变,很多想要学习Web前端进入IT行业的人都会担忧Web前端行业发展趋势如何.下面,老师就带大家了解一下2021年Web前端行业发展趋势如 ...

  6. 深圳Web前端学习:5G对Web前端发展的影响--千锋

    深圳Web前端学习:5G对Web前端发展的影响–千锋 5G浪潮的来临让全世界都为之关注,各个国家都在争夺它的主导权.它对软件行业影响是巨大的,深远的,甚至会导致行业的重新洗牌,和很多技术工种的兴衰.所 ...

  7. Delphi Web应用开发B/S框架推荐:《Delphi Web前端开发教程——基于TMS WEB Core框架》

    使用TMS WEB Core 发现Delphi软件开发的无限潜能-- 二十多年来,编程语言Delphi 以对 Windows 应用程序的快速可视化编程而闻名于世.尤其是轻松开发桌面数据库应用程序和快捷 ...

  8. Web前端培训:常用的Web前端开发框架有哪些?

    学习web前端技术的时候,我们会学到开发框架这一课,web前端的开发框架是有很多的,有一些是常用的,那么常用的Web前端开发框架有哪些呢?来看看下面的详细介绍. 常用的Web前端开发框架有哪些?程序员 ...

  9. 前端渲染和后端渲染,要说的都在这里?

    时下,前端 UI 设计越来越复杂,可谓"XX与XX齐飞,XX共XX一色". 越来越复杂的 UI 意味着越来越重的 渲染工作. 目前通常有两种选择:服务器渲染 与 客户端渲染 笔者是 ...

最新文章

  1. python考试pass or fail_请问老师为什么我输入的数据,预期结果是pass,我的预期因该是“fail”...
  2. 整理一份详细的数据预处理方法
  3. Solr Cache使用介绍及分析
  4. 第9件事 产品定位要解决的6个问题
  5. 能表示分数的计算机,分数计算器的实现
  6. 数十种TensorFlow实现案例汇集:代码+笔记
  7. haar级联分类器--人脸检测和匹配
  8. 天刀服务器维护到几点,3月3日服务器例行维护公告
  9. 必须收藏:20个开发技巧教你开发高性能计算代码
  10. No.4 Linux用户、组的创建、修改和权限的修改
  11. Pycharm 主题背景色的配置
  12. 二年级孩子适合学C语言吗,小孩子适合学习编程吗?孩童时期对变成的接受程度有多少呢?...
  13. 老饼教你深入浅出理解-《牛顿法求极值》
  14. 小时候玩过的游戏之八——玻璃弹珠
  15. 一个IOS音乐播放器源码
  16. 医院影像图像科室工作站PACS系统 DICOM 三维图像后处理与重建
  17. 数据挖掘入门(一)基本理论
  18. 钉钉在线课程开启屏幕共享时电脑蓝屏问题解决办法
  19. 【科普】浅谈NB-IoT
  20. 计算机科学与技术考研辅导班,[独峰考研]清华大学计算机科学与技术考研辅导班-清华计算机系考研经验真题...

热门文章

  1. C++ Type Trait
  2. 编写优质嵌入式C代码
  3. 基于system generator的整除除法设计
  4. 聊聊Neo4j图数据库的那些明显优势
  5. 微信小程序获取用户位置信息并显示到地图上
  6. 调用U9系统里的新增杂收服务服务
  7. 计算机考神经科学,科学网—神经科学杂谈6:电脑和人脑的最大不同--计算和记忆 - 吴景鹏的博文...
  8. 均值与期望到底是不是一回事?
  9. vue : 无法将“vue”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确, 然后再试一次 必解决技巧
  10. IDEA运行报Command line is too long和unable to find valid certification path to requested target