如何提高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 来剔除多余代码
二.如何**⽤**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 插件来进⾏公共模块抽取, 利⽤浏览器缓存可以⻓期缓存这些⽆需频繁变动的公共代码

相关推荐
@小红花24 分钟前
从0到1学习Vue框架Day03
前端·javascript·vue.js·学习·ecmascript
前端与小赵27 分钟前
vue3中 ref() 和 reactive() 的区别
前端·javascript·vue.js
魔云连洲41 分钟前
Vue的响应式底层原理:Proxy vs defineProperty
前端·javascript·vue.js
专注VB编程开发20年1 小时前
CSS定义网格的列模板grid-template-columns什么意思,为什么要用这么复杂的单词
前端·css
IT_陈寒1 小时前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
Hilaku1 小时前
深入URL和URLSearchParams:别再用正则表达式去折磨URL了
前端·javascript·代码规范
pubuzhixing1 小时前
Canvas 的性能卓越,用它解决一个棘手问题
前端
weixin_456904271 小时前
Vue.jsmain.js/request.js/user.js/store/index.js Vuex状态管理项目核心模块深度解析
前端·javascript·vue.js
伍哥的传说1 小时前
Vue 3.6 Alien Signals:让响应式性能飞跃式提升
前端·javascript·vue.js·vue性能优化·alien-signals·细粒度更新·vue 3.6新特性
永日456701 小时前
学习日记-HTML-day51-9.9
前端·学习·html