前端性能优化

19 篇文章 0 订阅
5 篇文章 0 订阅

性能优化

说到前端性能优化,看了许多文章,无非就是两大类:浏览器层面和http层面。

其中包括:

  1. 资源:资源合并压缩
  2. 图片:图片压缩与优化
  3. css与js的装载与执行
  4. 懒加载与预加载
  5. 重绘与回流
  6. 浏览器存储
  7. http缓存
  8. 服务端优化

1. 前端的本质

前端的本质实际上就是一个GUI软件

2. 前端性能的本质

  • 性能问题多种多样:瓶颈可能出现在网络传输过过程,造成前端数据呈现延迟。也可能是移动hybrid应用中,webview容器带来了瓶颈和限制。但是关于性能问题一般都弹不开Javascript单线程这个概念。
  • 浏览器解析和渲染DOM Tree和CSS Tree,解析执行JavaScript,几乎所有的操作都是在主线程中执行。因为JavaScript可以操作DOM,影响渲染,所以JavaScript引擎线程和UI线程互斥,换句话说,JavaScript代码执行会阻塞页面的渲染。
  • 深入理解http请求的过程是前端性能优化的核心

3. 浏览器请求从发送到返回都经历了什么

 

<1> 查询ip地址

  1. 浏览器解析出url中的域名。
  2. 查询浏览器的DNS缓存。
  3. 浏览器中没有DNS缓存,则查找本地客户端hosts文件有无对应的ip地址。
  4. hosts中无,则查找本地DNS服务器(运营商提供的DNS服务器)有无对应的DNS缓存。
  5. 若本地DNS没有DNS缓存,则向根服务器查询,进行递归查找。
  6. 递归查找从顶级域名开始(如.com),一步步缩小范围,最终客户端取得ip地址。

<2> 建立tcp链接,接入服务器

<3> 浏览器发起http请求

<4> 服务器后台操作并作出http响应

  1. http协议建立在tcp协议之上,http请求前,需先进行tcp连接,形成客户端到服务器的稳定的通道。俗称TCP的三次握手。若为HTTPS,多一个secureConnection,即SSL协议握手过程。此后每次通信都多加解密过程。clipboard.png
  2. tcp连接完成后,http请求开始,请求有多种方式,常见的有get,post等。
  3. http请求包含请求头,也可能包含请求体两部分,请求头中包含我们希望对请求文件的操作的信息,请求体中包含传递给后台的参数。
  4. 服务器收到http请求后,后台开始工作,如负载平衡,跨域等,这里就是后端的工作了。
  5. 文件处理完毕,生成响应数据包,响应也包含两部分,响应头和相应体,响应体就是我们所请求的文件。
  6. 经过网络传输,文件被下载到本地客户端,客户端开始加载。

<5> 网页的解析与渲染

  1. html最先被以字节流方式返回,然后转换成字符流,通过浏览器词法分析之后,相应的语法分析成相应的tocken,不断将nexttocken添加到dom树中,客户端浏览器加载了html文件后,由上到下解析html为DOM树(DOM Tree)。
  2. 遇到css文件,css中的url发起http请求。
  3. 这是第二次http请求,由于http1.1协议增加了Connection: keep-alive声明,故tcp连接不会关闭,可以复用。
  4. http连接是无状态连接,客户端与服务器端需要重新发起请求--响应。在请求css的过程中,解析器继续解析html,然后到了script标签。
  5. 由于script可能会改变DOM结构,故解析器停止生成DOM树,解析器被js阻塞,等待js文件发起http请求,然后加载。这是第三次http请求。js执行完成后解析器继续解析。
  6. 由于css文件可能会影响js文件的执行结果,因此需等css文件加载完成后再执行。
  7. 浏览器收到css文件后,开始解析css文件为CSSOM树(CSS Rule Tree)。
  8. CSSOM树生成后,DOM Tree与CSS Rule Tree结合生成渲染树(Render Tree)。
  9. Render Tree会被css文件阻塞,渲染树生成后,先布局,绘制渲染树中节点的属性(位置,宽度,大小等),然后渲染,页面就会呈现信息。
  10. 继续边解析边渲染,遇到了另一个js文件,js文件执行后改变了DOM树,渲染树从被改变的dom开始再次渲染。
  11. 继续向下渲染,碰到一个img标签,浏览器发起http请求,不会等待img加载完成,继续向下渲染,之后再重新渲染此部分。
  12. DOM树遇到html结束标签,停止解析,进而渲染结束。

Html 渲染过程的一些特点

  • 顺序执行,并发加载 并发度受浏览器域名的限制 设置3-4个cnd域名,防止达到并发上限
  1. 词法分析 tocken获取从上到下,从而导致html的解析从上到下
  2. 并发加载
  3. 并发上限
  • 是否阻塞

css阻塞

  1. Css head中阻塞页面的渲染
  2. Css 阻塞js的执行
  3. Css 不阻塞外部脚本的加载

Js 阻塞

  1. 直接引入的js阻塞页面的渲染
  2. Js不阻塞资源的加载
  3. Js顺序执行,阻塞后续js逻辑的执行

优化的方法

  1. DNS 缓存,减少DNS查询:将服务器域名的ip信息加入本地host文件。
  2. 网络请求的过程:CDN请求静态资源 CDN 的域名不要和主站的域名相同,防止访问CDN携带主站cookie
  3. 减少http请求大小,合并http请求,减少http请求数量,对于图片使用雪碧图,对于html文件和css文件,js文件分别进行合并操作。
  4. 接口缓存:浏览器的缓存策略
  5. 减少下载时间:压缩图片,使用压缩应用压缩文档中的空格,删除文件多余的语句和注释,创造自己的js精简库和精简框架,使用本地浏览器缓存。
  6. 提前渲染开始时间:将css链接放在html头部。
  7. 减轻解析器的阻塞:将js链接放在body尾部。
  8. 服务器端渲染

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值