首先仍是简单介绍一下 webpack-bundle-analyzer 是作什么的:vue
Visualize size of webpack output files with an interactive zoomable treemap.
一个很强大的用来优化打包以后文件提交的工具。webpack
在老版本的脚手架里面已经多帮你配置好了,在 build/webpack.prod.conf.js
文件中:web
判断是否配置了 bundleAnalyzerReport,若是配置了,加载 webpack-bundle-analyzer 工具包,调用了 BundleAnalyzerPlugin,最终仍是 push 到 plugins 对象中:npm
if (config.build.bundleAnalyzerReport) { const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin webpackConfig.plugins.push(new BundleAnalyzerPlugin()) }
在 config/index.js
文件中:配置了 build
对象的 bundleAnalyzerReport
json
module.exports = { build: { bundleAnalyzerReport: process.env.npm_config_report } }
那在新版本里面,咱们在 vue.config.js 中如何配置呢?函数
第一个想到的仍是经过 chainWebpack 配置,再看看它的官方说明:工具
是一个函数,会接收一个基于 webpack-chain 的 ChainableConfig 实例。
容许对内部的 webpack 配置进行更细粒度的修改。
chainWebpack: config => { // ... }
而后是如何经过 config
生成一个 plugin
:优化
咱们查看一下 webpack-chain
插件的 README.md
,有以下一段:ui
config .plugin(name) .use(WebpackPlugin, args)
参照如上格式,有 2 个示例以下:插件
// Examples config .plugin('hot') .use(webpack.HotModuleReplacementPlugin); config .plugin('env') .use(webpack.EnvironmentPlugin, ['NODE_ENV']);
因此,照着上面的模板,咱们也很简单就写出来了:
config .plugin('webpack-bundle-analyzer') .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
可是还不够,咱们须要加一些限制条件,相似老版本脚手架里面的:
if (process.env.npm_config_report) { // ... }
而后咱们能够在 package.json 中增长 scripts:
key 是:analyz
value 是:npm_config_report=true npm run build
"analyz": "npm_config_report=true npm run build"