web 性能优化

优化方向有两个:

HTTP 请求
JS 加载

打开浏览器控制台的网络,可以看到从拉取模版开始到首次渲染中间到底在加载什么,如果中间某些资源加载速度过慢,则可以从这方面入手,否则的话有可能是解析 js 速度过慢导致。

请求优化
合理使用缓存
合理使用缓存,降低请求等待的时间,可以通过达到性能优化

CDN 内容分发
将非核心资源通过 CDN 的方式进行分发,例如使用的第三方库(React、Vue、地图等),可以有效减小请求包的体积,同时稳定高速的 CDN 服务器也可以加快请求的速度。

CDN 通常会配合异步加载一起使用。

图片优化
使用合适的图片格式作为网站的图片,比如 WebP。具体看图片优化

HTTP/2
随着时间的推移,迁移到 HTTP/2 是不可避免的。目前浏览器对于 HTTP/2 的支持度都非常友好,同时相对于 HTTP/1,HTTP/2 在性能上有着非常显著的提升HTTP版本

资源压缩
目前浏览器大多都支持对压缩资源进行加载,比如 js、css 的 gzip。开启压缩后,会让资源的体积减小,从而降低请求时间。

加载优化
拆包
在不配置拆包的情况下,Webpack 会将所有的资源都打包在一个 js 文件中,这无疑会让请求时候的响应体积变得非常大,从而降低加载速度。
同时,不配置拆包,会在首次加载的时候加载一些无关的资源,浪费了一次宝贵的请求。
合理配置拆包,让每次请求都只请求对应的核心资源,从而达到按需加载的程度。
拆包通常的逻辑:
1. 业务代码和第三方依赖进行拆分
2. 对于第三方依赖:
将版本经常变动的与版本不怎么变动的进行拆分
版本不怎么变动的依赖可以合理配置 CDN
3. 对于业务代码:
将业务模块和公共模块进行拆分
业务模块也根据调用的次数进行拆分
将首屏模块单独进行拆分

异步加载
非核心的资源不需要在拉取模版之后立马就加载,可以使用异步加载,让这些非核心资源在视图构建完毕以后再进行加载

预加载
与首屏优化一样,路由跳转优化也是非常关键。我们可以通过判断是否需要进行路由跳转,在跳转之前做一些提前加载,从而达到跳转完成之后,资源立马加载完毕的效果从而提升加载速度

合理配置打包版本
首先我们需要明确一点,一般情况下,随着新标准的制定,浏览器厂商通常会着重对新标准的性能进行优化,而老标准的优化频率会慢慢降低,所以,我们编码的目标便是面向未来编程。

另外,目前我们主要是用 ES6+ 或 TS 进行编码,经过打包工具构建之后,性能往往比不上手写的代码,虽然随着工具的升级,性能会越来越好,但是编译后的代码,尤其是对 class 代码的编译,性能下降是非常明显的。

最后,编译后代码的体积会出现膨胀的情况,编译器使用了很多技巧来将 es6 转换成 es5,所以使用 es6 版本会让体积更小。

目前主流浏览器对于 ES6 的支持越来越好,打包的时候可以设置两个构建,对于支持度较好的浏览器版本,使用更高级的版本,从而达到减小包的体积来达到更快的加载速度。

同时,可以使用 的方式来实现动态加载 es6 代码,详情可以查看随着 Vue3 一起发布的 Vite。

摇树
我们可能在编码过程中会书写一些无用代码,但是这些无用代码却会被打包构建工具与核心资源打包在一起,这无疑会增大请求时相应的体积,从而影响我们加载的速度。所以在打包过程中使用摇树的方式,可以将无用的代码清除,从而减小包的体积来达到性能提升。

多线程
现代浏览器大都支持 Worker,这是一种浏览器实现多线程的方式,他可以与 JS 线程、GUI 线程同时运行,通过 Worker,我们可以将一些复杂繁琐的操作交给子线程来完成,从而避免渲染线程的阻塞,来达到性能的优化。
但是,线程之间的通信是需要消耗时间的,所以多线程技术应该合理地使用。

使用外链样式而非内联样式
浏览器对于外链样式处理的速度会比内联样式更快,这也是为什么 style-components 这么火的原因。
同时优先使用浏览器的 html 标签 link,而不是 css 中的 @import,原因在于 link 的加载是和 GUI 线程并行的,但是 @import 需要等待 HTML 完全处理完成之后再进行加载。

体验优化
骨架屏
使用 loading 图或者是骨架屏,可以一定程度上减少用户等待加载的焦虑感,让用户感觉没有等太久,这就是用户体验级的优化。

服务端渲染
在条件允许的情况下,将客户端渲染迁移到服务端渲染,利用服务端高性能的表现,可以实现用户拉去到模版之后立马显示视图,省去中间 JS 加载的过程。

动画
直接操作 DOM,有可能会引起大面积的重排和重绘,从而引起掉帧的情况,导致用户体验下降。
合理使用 CSS3 GPU 加速,可以避免使用动画之后的重排和重绘,达到更流畅的动画效果。
有一说一,开启 CSS3 GPU 加速是非常消耗功耗的,所以在移动端上面谨慎使用。

虚拟滚动
我们知道,页面进行滚动的时候,也会触发浏览器的重排,如果此时前端需要渲染大量数据,而且还不允许分页,这种情况下会导致浏览器的掉帧、卡顿甚至假死的情况。

这种情况下,如果不能使用分页进行优化,通常我们会使用虚拟滚动的方式来解决问题。

因为 DOM 元素的创建和渲染需要的时间成本很高,在大数据的情况下,完成渲染列表所需要的时间不可接受,所以我们可以只渲染可视区域,从而达到极高的初次渲染性能。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值