访问一个网页,浏览器至少发起几次http请求

有次面试被问到打开一个url浏览器至少发起几次http请求,刚开始有点懵,心想浏览器至少发生一次http请求啊这个有什么好问的?get不到面试官的care点!回头去网上查了一下资料才恍然大悟原来是要考察服务端渲染和客户端渲染的认识。那到底什么是客户端渲染什么是服务端渲染呢?下面让我细细道来。

服务端渲染

说白了就是服务端接收到客户端发来的html字符串时,然后使用模板引擎(ejs、jade等)将数据传到模板,最后返回一个数据+html的字符串给浏览器,浏览器自动解析成一个完成的html页面,很明显浏览器渲染过程只发生了一次网络请求服务端渲染过程下面挂上张李鹏周老师的图:


客户端渲染

客户端向服务端发起请求,服务端不做任何处理,直接以原文件的形式返回给客户端,然后渲染html页面,当遇到ajax请求,有发起一次网络请求根据接口返回相应的数据,客户端结合模板引擎(art-template)和数据拼装最后以dom形式插入html页面,当然这种方式是比较老套的方式了,如当下用得火热的 spa 框架,Angular、React、Vue等。很明显浏览器渲染过程发生了两次网络请求,客户端渲染过程再次挂上张李鹏周老师的图:

 

 

服务端渲染和客户端渲染的优缺点

服务端渲染和客户端渲染抉择

那么我们到底什么时候用服务端渲染什么时候用客户端渲染呢?一般网站既不是纯异步也不是纯服务端渲染出来的例如京东的商品列表就采用的是服务端渲染,目的了为了 SEO 搜索引擎优化,而它的商品评论列表为了用户体验,而且也不需要 SEO 优化,所以采用是客户端渲染。

总结
若网站是纯服务端渲染,那么浏览该网站至少发起一次请求,否则浏览该网站至少发起两次请求

原文参考:https://jkchao.cn/article/5a11155fb520d115154c8fa1

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值