到vue-cli 3.0后,webpack配置被整合到vue-cli的配置中了,需要配置一些打包插件比較麻煩了,比如優化momentjs
壓縮包,使用webpack-bundle-analyzer
等…
研究后發現vue-cli 3.0使用了chainWebpack
來支持額外的插件配置,其實和2.0是差不多的
我們這里使用momentjs
,lodash
和webpack-bundle-analyzer
來演示如何配置chainWebpack
安裝依賴
chainWebpack
已經默認包含在vue-cli中了,無需安裝
只需安裝webpack-bundle-analyzer
和momentjs
,lodash
,我用的是yarn,所以
yarn add webpack-bundle-analyzer lodash-webpack-plugin --dev //優化要用到的插件
創建vue.config.js
在根目錄下創建vue.config.js
vue.config.js
var webpack = require('webpack') //引入webpack庫 var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin //引入webpack-bundle-analyzer module.exports = { chainWebpack: config => { config.plugin('ignore') .use(new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/));//忽略/moment/locale下的所有文件 config.plugin('analyzer') .use(new BundleAnalyzerPlugin())//使用webpack-bundle-analyzer 生成報表 config.plugin("loadshReplace") .use(new LodashModuleReplacementPlugin());//優化lodash } }