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

如何⽤webpack 来优化前端性能

如何⽤webpack 来优化前端性能?

⽤webpack 优化前端性能是指优化 webpack 的输出结果,让打包的最终结果在浏览器运⾏快速⾼效。

  • 压缩代码:删除多余的代码、注释、简化代码的写法等等⽅式。可以利⽤webpack的 UglifyJsPlugin 和 ParallelUglifyPlugin 来压缩JS⽂件, 利⽤ cssnano (css-loader?minimize)来压缩 css;
  • 利⽤CDN 加速: 在构建过程中,将引⽤的静态资源路径修改为 CDN 上对应的路径。可以利⽤webpack 对于 output 参数和各 loader 的publicPath 参数来修改资源路径;
  • Tree Shaking: 将代码中永远不会⾛到的⽚段删除掉。可以通过在启动 webpack 时追加参数 --optimize-minimize 来实现;
  • Code Splitting: 将代码按路由维度或者组件分块(chunk),这样做到按需加载,同时可以充分利⽤浏览器缓存;
  • 提取公共第三⽅库: SplitChunksPlugin 插件来进⾏公共模块抽取, 利⽤浏览器缓存可以⻓期缓存这些⽆需频繁变动的公共代码。
如何提⾼webpack 的构建速度?
  1. 多⼊⼝情况下,使⽤ CommonsChunkPlugin 来提取公共代码;
  2. 通过 externals 配置来提取常⽤库;
  3. 利⽤ DllPlugin 和 DllReferencePlugin 预编译资源模块 通过DllPlugin 来对那些我们引⽤但是绝对不会修改的 npm 包来进⾏预编译,再通过DllReferencePlugin 将预编译的模块加载进来;
  4. 使⽤ Happypack 实现多线程加速编译;
  5. 使⽤ webpack-uglify-parallel 来提升 uglifyPlugin 的压缩速度。原理上 webpack-uglify-parallel 采⽤了多核并⾏压缩来提升压缩速度;
  6. 使⽤ Tree-shaking 和 Scope Hoisting 来剔除多余代码。
http://www.lryc.cn/news/121585.html

相关文章:

  • 人机交互中的混合多重反馈
  • CSS:服务器字体 与 响应式布局(用法 + 例子 + 效果)
  • 24届近3年上海电力大学自动化考研院校分析
  • PostgreSQL查询慢sql原因和优化方案
  • Leetcode 21. 合并两个有序链表
  • [tool] Ubuntu 设置开机启动python脚本
  • 「何」到底该读「なん」还是「なに」?柯桥学日语
  • github - 创建组织-Team
  • 【Transformer】自注意力机制Self-Attention | 各种网络归一化Normalization
  • 沁恒ch32V208处理器开发(四)串口通信
  • 【BASH】回顾与知识点梳理(十八)
  • linux 目录操作命令
  • React Dva项目小优化之redux-action
  • Kotlin反射访问androidx.collection.LruCache类私有变量
  • 高级进阶多线程——多任务处理、线程状态(生命周期)、三种创建多线程的方式
  • 【 K8S 】 Pod 进阶
  • 众和转债,宏微转债,阳谷转债上市价格预测
  • MySQL~事务的四大特性和隔离级别
  • JMeter处理接口签名之BeanShell实现MD5加密
  • 【Golang】一文学完 Golang 基本语法
  • 《Java-SE-第三十五章》之方法引用
  • Effective Java笔记(33)优先考虑类型安全的异构容器
  • 释放AI创作潜能:从大模型训练到高产力应用
  • Ajax 笔记(一)—— Ajax 入门
  • Android Studio跳过Haxm打开模拟器
  • 从一个GPU到多个GPU
  • 小白编写一个Chrome
  • 自然语言处理学习笔记(六)————字典树
  • WPF实战项目十一(API篇):待办事项功能api接口
  • ffmpeg给视频添加时间水印,准确且不模糊