引言
webpack-bundle-analyzer
作为可视化的 webpack
打包后文件的分析插件,是比较成熟的方案。
webpack-bundle-analyzer作用
:
- 认识打包后的文件和大小;
- 以便优化打包后的文件。
安装
npm install webpack-bundle-analyzer -D
复制代码
vue.config.js配置
module.exports = {
chainWebpack: config => {
config
.plugin('webpack-bundle-analyzer')
.use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
},
}
复制代码
使用
npm run serve (这时会执行webpack-bundle-analyzer插件功能 完成优化后可自行删掉 配置 )
结果
打开网站后,看到如下结
可以看到,在这里项目中, chunk-vendors.js 文件很大,大概占74%。这个文件是什么?
chunk-vendors.js 文件一般是第三方模块或供应商模块。通常,/node_modules
中的第三方包都会打包到 chunk-vendors.js
中,自然会出现文件过大的问题。
优化方案
方式1 Gizp压缩
使用 compression-webpack-plugin 插件,将文件压缩成gzip文件。(在Vite项目里用vite-plugin-commpression插件)
安装插件——npm安装。
了解到还有一种brotli压缩,和gzip算是目前主流的压缩程序,但是前者只适用于https通信。
1 | npm install --save-dev compression-webpack-plugin |
方式2 配置分割
通过 webpack
前端配置,将第三方包分开打包,这样不会将所有第三方包都打包到 chunk-vendors.js
文件
1 | configureWebpack: { |
方式3 CND链接
比如将有些大的 js
、css
通过 cdn
的方式链接,可以多种方案配合一起使用的。
下图是我使用方法2得到的结果,可以看到原来的问价被分割成了很多js文件。
参考博客
vue3.0 + typescript + webpack-bundle-analyzer实现代码分析和CDN - 掘金
https://blog.bitsrc.io/5-methods-to-reduce-javascript-bundle-size-67f2e1220457