webpack

webpack打包结果优化

优化打包结果的核心目标就是让打出来的包体积更小。

  1. 打包体积分析:使用webpack-bundle-analyzer来分析,一般脚手架里直接运行命令行就能生成打包体积图,很方便,然后可以根据包体积能定向优化。
  2. 代码压缩:使用UglifyJsPlugin、MiniCssExtractPlugin等插件来对JS代码和CSS代码进行压缩,减小代码体积,实际开发中一般脚手架也会默认有压缩的配置。
  3. 使用懒加载:可以使用Webpack的动态导入功能,实现懒加载,在需要时再加载代码块。这可以缩短首屏加载时间,提升体验。
  4. 开启gzip:使用compression-webpack-plugin插件,生成额外的gzip静态文件,然后部署时再开启Nginx的gzip即可。(需要前端和服务端一起配置,也可以服务端配置,前端不用配置)
  5. 使用splitChunks提取公共代码,在脚手架中一般是默认开启的。
  6. 分离第三方库:将第三方库从应用程序代码中分离出来,单独打包,这样可以提高缓存效率并减小应用程序代码的大小。
  7. 开启Tree Shaking,对于Vue和React项目,一般是默认开启Tree Shaking的,我们在编写代码时尽量使用ES模块化语法,就可以了。
  8. 使用Module Federation:Module Federation是webpack中的新特性,它允许将应用程序拆分成多个独立的bundle,并在运行时进行动态加载,可以减少应用程序的初始加载时间。

webpack打包时间优化

1.1 开发阶段

  1. 使用缓存:可以使用Webpack的缓存功能,将打包结果缓存起来以避免重复构建。可以使用cache-loader或hard-source-webpack-plugin等插件来实现缓存。
  2. 使用 DllPlugin:DllPlugin 是 Webpack 的一个插件,它可以将一些不经常变动的第三方库预先打包好,然后在开发过程中直接使用。这样可以减少每次构建时对这些库的重复打包,提高构建速度。
  3. 配置合适的SourceMap策略:在开发环境下,开启 SourceMap 可以帮助我们快速定位错误和调试代码。但是开启 SourceMap 会降低构建速度,所以需要权衡是否开启。
  4. 多线程并行打包:可以使用thread-loader或happypack开启多线程并行构建,但是并不是一定会提升性能,需要结合场景来自行取舍,比较适合单个耗时长的任务。
  5. 配置模块解析:Webpack 在模块解析时会搜索 node_modules 目录,这个过程比较耗时。为了减少搜索时间,我们可以使用 resolve.alias 配置选项来告诉 Webpack 直接使用特定的路径来查找模块。
相关推荐
二两锅巴1 分钟前
📺 无需Electron!前端实现多显示器浏览器窗口精准控制与通信
前端
炸土豆5 分钟前
防抖节流里的this传递
前端·javascript
用户4099322502126 分钟前
Vue3中动态样式数组的后项覆盖规则如何与计算属性结合实现复杂状态样式管理?
前端·ai编程·trae
山璞8 分钟前
Flutter3.32 中使用 webview4.13 与 vue3 项目的 h5 页面通信,以及如何调试
前端·flutter
努力早日退休11 分钟前
Antd Image标签父元素会比图片本身高几个像素的原因
前端
林希_Rachel_傻希希11 分钟前
手写Promise--教学版本
前端·javascript·面试
ETA815 分钟前
`console.log([1,2,3].map(parseInt))` 深入理解 JavaScript 中的高阶函数与类型机制
前端·javascript
呼叫694515 分钟前
图片列表滚动掉帧的原因分析与解决方案
前端
狗哥哥18 分钟前
AI 驱动前端自动化测试:一套能落地、能协作、能持续的工程化方案
前端·测试
全栈老石22 分钟前
别再折腾端口转发了:使用 Cloudflare Tunnel 优雅地分享你的 localhost
前端·后端·全栈