前端性能优化方案

一、HTML优化策略​

1、减少DOM层级​​

javascript 复制代码
<!-- 避免 -->

<div><div><div><p>内容</p></div></div></div>

<!-- 推荐 -->

<div class="content">内容</div>

原因:嵌套过深会增加渲染树的构建时间

​​2、异步加载非关键资源​​

javascript 复制代码
<!-- defer/async 区别 -->

<script defer src="non-critical.js"></script>  <!-- DOM解析后执行 -->

<script async src="analytics.js"></script>    <!-- 下载完立即执行 -->

​​3、预加载关键资源​​

javascript 复制代码
<link rel="preload" href="font.woff2" as="font" type="font/woff2" crossorigin>

<link rel="prefetch" href="next-page.html">  <!-- 空闲时预加载 -->

二、CSS优化策略

1、关键 CSS 内联避免阻塞渲染

javascript 复制代码
<!-- 将非关键CSS移到body底部 -->
<link rel="stylesheet" href="non-critical.css" media="print" onload="this.media='all'">

2、减少页面重绘和回流

回流(reflow):是指由于DOM结构或样式发生改变,浏览器需要重新计算元素的几何属性,然后重新布局页面的过程

重绘(repaint):是指当元素样式发生改变,但不影响布局时,浏览器只需要重新绘制受影响的部分,而不需要重新计算布局

  • 尽量减少深度嵌套或复杂选择器的使用,以提高 CSS 渲染效率
  • 避免频繁的DOM操作‌:频繁修改DOM会导致重排和重绘,尽量批量处理DOM修改,或者使用DocumentFragment来构建DOM树后再添加到页面
  • 合理使用GPU加速 :使用CSS3的硬件加速功能,可以将需要进行动画或变换的元素提升到一个独立的渲染层,从而避免浏览器进行重新布局(Reflow)和绘制(Repaint)‌。可以触发 GPU 硬件加速的 CSS 属性包括transformfilterwill-changeposition:fixed

3、图像压缩、格式选择和精灵图

  • WebP 格式替代 JPEG/PNG(兼容性需考虑):相比于PNG和JPEG的优点主要包括更小的文件大小、更高的压缩效率和更好的图像质量保持。
  • TinyPNG压缩图片
  • 精灵图:将许多小图像合并成一个大图像。这样,在加载页面时,只需要获取一个图像来显示多个页面元素

4、图片懒加载

仅在图像进入浏览器视口时加载图像

将 img 的src属性设置成一张默认图片,在图片加载出来之前显示默认图片。

用data-自定义属性名 (data-src) 接收图片的真实路径,待图片滚动到可视区域的时候开始加载图片,待图片加载出来之后替换掉之前的默认图片

三、Javascript优化策略​

1、防抖与节流

防抖,就是指触发事件后,在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执行时间。防抖确保函数在一段时间内只执行一次,且是在最后一次触发事件后执行。

节流,就是指连续触发事件但是在 n 秒中只执行一次函数。节流确保函数按照固定的时间间隔执行。

2、虚拟列表优化长列表

3、Web Worker处理密集型任务​

浏览器提供的 JavaScript 多线程解决方案,它允许在主线程之外运行脚本,避免阻塞 UI 渲染

四、webpack优化策略

减少打包体积(减小最终资源大小)

优化点 做法
✅ Tree Shaking 删除未使用代码(使用 ES6 import/export 模块规范)
✅ 压缩 JS 使用 TerserPlugin 进行代码压缩(默认内置于 mode=production)
✅ 压缩 CSS 使用 css-minimizer-webpack-plugin
✅ 压缩图片 使用 image-webpack-loader 或在打包前压缩
✅ 忽略 Moment.js 的多语言 new webpack.IgnorePlugin({ resourceRegExp: /^\.\/locale$/, contextRegExp: /moment$/ })
✅ 使用 CDNs 将大库(如 React、Vue)用 CDN 引入,设置为 externals
✅ 使用按需加载库 例如 lodash-es + babel-plugin-lodash

五、CDN优化策略

CDN 优化(内容分发网络)是部署在全球各地的缓存服务器集群,将静态资源(图片、JS、CSS 等)缓存到离用户更近的服务器,提升加载速度,减少延迟。

CDN 优化策略

优化点 说明 配置建议
① 使用 CDN 加速静态资源 加快加载速度(图片、JS、CSS、字体等) 将资源上传到 CDN 服务商(如阿里云、腾讯云、七牛、Cloudflare)
② 设置域名分发 资源使用独立域名,防止与主站 Cookie 冲突 如静态资源用 static.example.com
③ DNS 预解析 提前建立连接 HTML 添加:<link rel="dns-prefetch" href="//static.example.com">
④ preconnect 提前建立 TCP + TLS 连接 <link rel="preconnect" href="https://cdn.example.com">
⑤ CDN 缓存控制 控制资源更新策略 在 CDN 控制台设置 Cache-ControlExpires

六、浏览器缓存优化策略

浏览器缓存通过存储资源副本(CSS、JS、图片等),避免重复请求服务器,提升性能

两类缓存方式

类型 说明 特点
① 强缓存(强制使用缓存) 不发请求,直接读取缓存资源 Cache-ControlExpires 控制
② 协商缓存(可能使用缓存) 发送请求,服务端判断是否使用缓存 ETagLast-Modified 控制
相关推荐
Boilermaker1992几秒前
【Java EE】SpringIoC
前端·数据库·spring
wjs20241 分钟前
SOAP Header 元素
开发语言
中微子11 分钟前
JavaScript 防抖与节流:从原理到实践的完整指南
前端·javascript
无限远的弧光灯21 分钟前
c语言学习_函数递归
c语言·开发语言·学习
天天向上102426 分钟前
Vue 配置打包后可编辑的变量
前端·javascript·vue.js
趣多多代言人28 分钟前
从零开始手写嵌入式实时操作系统
开发语言·arm开发·单片机·嵌入式硬件·面试·职场和发展·嵌入式
胖大和尚38 分钟前
C++项目学习计划
开发语言·c++·学习
开开心心_Every40 分钟前
全能视频处理工具介绍说明
开发语言·人工智能·django·pdf·flask·c#·音视频
芬兰y42 分钟前
VUE 带有搜索功能的穿梭框(简单demo)
前端·javascript·vue.js
好果不榨汁1 小时前
qiankun 路由选择不同模式如何书写不同的配置
前端·vue.js