前言
在日常开发中,有很多场景需要我们去做好前端优化,为了防止遗忘,加深记忆,今天参阅了一些资料以及自己的一些总结,梳理出来15条优化技巧。
1.合并文件
css、js合并,减少http请求数,每次http请求的建立,都需要进行三次握手,断开时需要四次挥手,http请求数量减少后,对页面的加载速度有很大的提升。
2.雪碧图
css sprites,雪碧图,合并多个图像为一个,通过background-position使用图像。
3.使用base64图片
小图片使用data:url引用,减少不必要的请求。
示例:

4.使用缓存
设置缓存来减少不必要的网络请求。强缓存/协商缓存
5.gzip压缩
gzip压缩本质上是一种服务器编码,客户端解码的过程
开启gzip压缩后的请求流程
- 1.浏览器请求服务器时头信息Accept-Encoding: gzip, deflate来告诉服务器,浏览器支持gzip压缩
- 2.服务器收到请求后,先生成response,然后通过gzip对response进行编码,并增加Content-Encoding:gzip头信息返回给客户端
- 3.客户端收到response后,根据gzip进行解码。
6.css引入位置
将css的引入写在head标签内
尽管浏览器没有限制css的引入位置,但是css写在head内可以加快css的加载,避免页面不必要的重绘,css加载会阻塞后续js的执行以及dom树的渲染,所以引入最好位置就是head内js代码之前。
7.避免使用css表达式expression
示例:
background-color: expression( (new Date()).getHours()%2 ? "#B8D4FF" : "#F08A00" );
每当鼠标移动或者滚动,都会触发表达式,这样会拖慢页面其他脚本执行效率,影响体验。
8.js/css使用外部引入
将不常用的js或css使用外部引用,利用缓存来加快页面访问速度(相关参考强缓存、协商缓存)。
9.资源压缩
js、css删减注释,压缩,减小js、css体积,加快加载速度。
10.开启持久连接
每个连接可以处理多个请求-响应事务
非持久连接,当响应完毕后,当前连接会关闭,当开启持久连接后,当前连接在接受响应后还可以继续请求。
http开启keepalive,复用http请求,避免频繁建立http请求
11.不要过度使用post
- post请求浏览器分为两步 1.发送头数据head2.发送请求体。
- get请求只发送一个tcp数据包
13.控制页面dom数量
当页面解析渲染时,需要将html构建为dom树,解析css生成CSSOM树,将DOM与CSSOM合并生成渲染树,当dom数量过多时会影响dom解析以及最终的渲染时间,所以减少dom数量可以加速页面的渲染时间。
控制台查看dom数量:
document.getElementsByTagName('*').length
14.控制cookie
减少cookie大小,cookie会随每次请求提交到服务器,也会随响应返回到客户端,cookie会影响请求跟响应数据包大小。
15.使用事件代理
事件代理又被称为事件委托,是事件绑定中的一个常用技巧,就是把绑定在子元素上的响应事件委托给父元素,减少事件注册。原理为DOM的事件冒泡,使用事件代理,由父组件代理子组件事件。
事件传播:
- 捕获阶段 从window对象到目标阶段,称之为捕获阶段。
- 目标阶段 事件在目标上
- 冒泡阶段 从目标阶段一层层向上传递称之为冒泡阶段。
16.不要给img标签的src设置为空
老版本浏览器如果检测到src为空,还是会向服务器发送请求,如果想要使用图片懒加载功能,最好给图片设置一个默认图。
图片懒加载实现步骤:
- 客户端图片设置默认src为默认图
- 客户端请求服务器,获取图片列表
- 客户端拿到图片列表后将图片地址赋值给img标签的自定义属性,例如data-src
- 监听图片是否在可视范围,如果图片在可视范围,则把图片的data-src赋值给src
- img根据src请求服务器获取图片资源