当前位置: 首页 > news >正文

前端性能优化方案

一、HTML优化策略​

1、减少DOM层级​​

<!-- 避免 --><div><div><div><p>内容</p></div></div></div><!-- 推荐 --><div class="content">内容</div>

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

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

<!-- defer/async 区别 --><script defer src="non-critical.js"></script>  <!-- DOM解析后执行 --><script async src="analytics.js"></script>    <!-- 下载完立即执行 -->

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

<link rel="preload" href="font.woff2" as="font" type="font/woff2" crossorigin><link rel="prefetch" href="next-page.html">  <!-- 空闲时预加载 -->

二、CSS优化策略

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

<!-- 将非关键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 控制
http://www.dtcms.com/a/205977.html

相关文章:

  • 使用mlpack训练分类网络
  • 101个α因子#20
  • 在 Windows 10 11 中运行 wsl.exe --update 时,如果遇到下载速度慢的问题,可以尝试以下几种加速方法:
  • python安装与使用
  • Python字符串格式化(二): f-string的进化
  • Dify大语言模型应用开发环境搭建:打造个性化本地LLM应用开发工作台
  • 自定义类型-联合体
  • web第六次课后作业--使用ApiFox实现请求响应操作
  • 智慧在线判题OJ系统项目总体,包含功能开发思路,内部中间件,已经部分知识点
  • Python结合ollama和stramlit开发聊天机器人
  • 黑马点评前端Nginx启动失败问题解决记录
  • 响应式架构下的调试挑战:WebDebugX 如何帮助前端稳住场面?
  • python实现web请求
  • 解决weman框架redis报错:Class “llluminatelRedis\RedisManager“ not found
  • web实验(2)
  • 【Dify平台】使用Dify API 实现网页内嵌式AI助手
  • Redis实战篇Day01(短信登录篇)
  • 谷歌medgemma-27b-text-it医疗大模型论文速读:多语言大型语言模型医学问答基准测试MedExpQA
  • PyTorch可视化工具——使用Visdom进行深度学习可视化
  • java 基础知识巩固
  • 论文阅读笔记——PixArt-α,PixArt-δ
  • [Harmony]网络请求
  • 【COMPUTEX 2025观察】NVIDIA开放NVLink:一场重构AI算力版图的“阳谋“
  • 应用案例 | 集成Docker,解锁 HMI/网关的定制化应用
  • 数据库基础面试题(回答思路和面试建议)
  • 力扣第450场周赛
  • upload-labs靶场通关详解:第14关
  • python:基础爬虫、搭建简易网站
  • Intel oneAPI 入门
  • 浙江大学python程序设计(陈春晖、翁恺、季江民)习题答案-第八章