前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >客户端渲染和服务器渲染的区别

客户端渲染和服务器渲染的区别

作者头像
@零一
发布2021-01-29 16:07:04
6.2K0
发布2021-01-29 16:07:04
举报
文章被收录于专栏:前端印象前端印象

客户端渲染和服务器渲染的区别

前言

我们都知道,网页上的很多内容之所以能那么丰富,是因为大量的css、js去渲染出这个页面。那么他们是如何渲染的呢?那么就要说到我们本文的两种渲染方式了,即客户端渲染和服务端渲染。

  • 公众号:前端印象
  • 不定时有送书活动,记得关注~
  • 关注后回复对应文字领取:【面试题】、【前端必看电子书】、【数据结构与算法完整代码】、【前端技术交流群】

正文

本文将分别讲述两种渲染方式的区别和他们各自的优缺点,以及他们在真实项目中的运用。如果不想看具体过程讲解的可以直接跳到最后的总结看结论.

一、客户端渲染

图片讲解

在这里插入图片描述
在这里插入图片描述

文字讲解

看了图后,我给大家总结一下,大致过程就是 : 用户输入地址,客户端向服务器发送请求 => 服务器传给浏览器相应的网页文件 => 浏览器解析文件 => 遇到ajax请求则向服务器再次请求一些数据 => 服务器再次向浏览器发送相应的数据 => 浏览器拿到ajax请求返回的数据后,将数据渲染在页面上

真实的客户端渲染案例

在上面我们也看到了,客户端渲染是在请求回数据后就已经开始渲染了,只是有些数据还没拿到,暂时没法渲染,不过大部分的页面内容我们都已经可以看到了,所以客户端渲染可以完成页面的局部刷新。例如JD的商品评论数据

在这里插入图片描述
在这里插入图片描述

大家看,我在点击评论的下一页时,整个页面没有刷新,浏览器上的网址也没有变化,只有评论的内容做了一个刷新,这就是一个典型的客户端渲染的例子,进入这个页面时,其他的内容都被浏览器渲染好了,而评论信息是在我们点击下一页时,客户端向服务器发送ajax请求,拿到了这一页的评论信息,再在这个部分做一个局部的数据重新渲染。

优点

  1. 可以向用户快速展示页面的内容,增加用户体验
  2. 给别人爬虫爬取相应的内容增加一定的困难

缺点

  1. 可能需要向服务器请求多次数据
  2. 不利于SEO 搜索引擎优化,即百度、搜狗等搜索引擎搜索不到客户端渲染的数据

二、服务器渲染

图片讲解

在这里插入图片描述
在这里插入图片描述

文字讲解

同样的,看完图我给大家总结一下,服务器渲染的步骤就是: 客户端向服务器发送一次请求 => 服务器接收请求,并在服务端操作网页文件,将对应数据导入文件 => 服务器在服务端渲染好整个网页,发送给客户端 => 客户端接收服务器发送过来的网页文件,不需要做任何操作,直接呈现

真实的服务器渲染案例

在这里插入图片描述
在这里插入图片描述

大家看,我在电脑的分类购物列表中,点击下一页时,整个页面做了一个刷新,浏览器上的网址也做了变化,这就是服务器渲染的一个典型案例,整个网页做一个刷新,正应对了我们上面的图片讲解,是浏览器向服务器请求,服务器给浏览器发送一整个页面。

优点

  1. 只需要向服务器请求一次
  2. 利于SEO 搜索引擎优化,即能被搜索引擎搜索到,能向用户展示你网页的东西

缺点

  1. 如果数据量过大,在服务器渲染的时间就会过长,造成浏览器暂时的空白
  2. 容易被爬虫爬取

三、如何区分客户端渲染和服务器渲染

  • 第一种方法 若页面做整体的刷新,即网址发生改变,就是服务器渲染 若页面做了局部刷新,即网址没发生改变,就是客户端渲染
  • 第二种方法(有gif动图展示) 若查看网页源代码时,查找不到网页中的一些内容,那就是客户端渲染 若查看网页源代码时,能找到网页中对应的内容,那就是服务器渲染
在这里插入图片描述
在这里插入图片描述

大家看,这个商品的名称在网页源代码中,能被搜索到,说明该条数据是被服务器渲染出来的。

在这里插入图片描述
在这里插入图片描述

大家看,这个商品的评论信息在网页源代码中,不能被搜索到,说明该条数据是被客户端渲染出来的。

四、总结

客户端渲染:

  • 页面的渲染工作都是由浏览器来完成的,服务器只是负责提供数据。
  • 客户端渲染能尽早的把页面展示给用户,用户体验好
  • 不容易被爬虫爬取数据,同时也无法被搜索引擎搜索到

服务器渲染:

  • 页面渲染的工作都是由服务端来完成的,数据也是由服务端提供的,浏览器只负责展示页面内容
  • 容易被爬虫爬取数据,同时能被搜索引擎搜索到,能在搜索引擎中向用户展示数据

那是用客户端渲染好还是服务器渲染好呢? 其实一般的页面中,两种渲染是相结合着使用的,因为我们会有些数据不想过早的传过来,想要被用到时再去拿数据,同时也不想被爬虫那么轻易的爬取,而且也不需要被搜索引擎搜索并展示,我们就可以用客户端渲染,例如我们本文中提到的商品评论信息。 但有时,我们想让我们网页的数据被搜索引擎搜索到,能让用户在使用搜索引擎的时候,查找到我们的数据信息,我们就可以使用服务器渲染。例如我们本文提到的电商网站的商品的基本信息,商品能被用户在搜索引擎搜索到,才能有更大的机会卖出去嘛,哈哈哈 这个解释应该挺贴切了吧。

结束语

好了,给大家讲了那么多,也是想让大家了解一下这两种渲染具体是怎么做的,同时也是帮我自己巩固一下知识点,毕竟每天学习的东西那么多,但记住的又很少。希望这篇文章对大家有所帮助~

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-05-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 客户端渲染和服务器渲染的区别
  • 前言
  • 正文
    • 一、客户端渲染
      • 图片讲解
      • 文字讲解
      • 真实的客户端渲染案例
      • 优点
      • 缺点
    • 二、服务器渲染
      • 图片讲解
      • 文字讲解
      • 真实的服务器渲染案例
      • 优点
      • 缺点
    • 三、如何区分客户端渲染和服务器渲染
      • 四、总结
      • 结束语
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档