在項目打包上有兩個目標:減少打包代碼體積和加快打包速度
1. 減少打包體積:
(1)對於用的比較少的庫,可以去掉(我去掉了jquery以及lodash),用到的地方,參考源碼自己寫
(2)非用不可的又比較大的庫(我這里用了monaco-edit),使用cdn方式引入
(3)按需加載
(路由懶加載配合webpack'的require.ensure實現: 其實總的體積並沒變,但是會提高首頁加載速度)
2. 加快打包速度:
這里推薦一篇個人感覺很棒的文章 https://juejin.im/post/5bfa696d51882579117f7d26
我目前做了這些:
(1)vue-cli2升級到vue-cli3,順便webpack2升級到webpack4,構建速度一下子從3分鍾左右提升到不到1分鍾(vue-cli3升級過程 https://www.cnblogs.com/XHappyness/p/9989693.html)
(2)使用 DllPlugin 進行預編譯,過程如下:
· npm install webpack-cli --save-d
· 獨立出一套webpack配置webpack.dll.conf,用dllPlugin定義要打包的dll文件;這里我在根目錄下新建webpack.dll.conf.js 內容如下

const path = require("path"); const webpack = require("webpack"); module.exports = { entry: { vendor: [ "vue-router/dist/vue-router.esm.js", "vuex/dist/vuex.esm.js", "axios" ] }, output: { path: path.join(__dirname, "public/vendor"), filename: "[name].dll.js", library: "[name]_[hash]" // vendor.dll.js中暴露出的全局變量名 }, plugins: [ new webpack.DllPlugin({ path: path.join(__dirname, "public/vendor", "[name]-manifest.json"), name: "[name]_[hash]", context: process.cwd() }) ] };
注意;在vue-cli3中一定要把生成的dll放到public中或者自己去配置 publicPath (沒仔細看文檔掉進坑)
· package.json中定義運行webpack.dll.conf.js的命令
{ ··· "scripts": { "serve": "npm link typescript && vue-cli-service serve", "dll": "webpack -p --progress --config ./webpack.dll.conf.js", ··· }, ··· }
· 運行npm run dll命令生成dll
· index.html中加載生成的dll文件
<script src="./vendor/vendor.dll.js"></script>
· 以上已經完成預編譯並載入;但是一定不要忘記webpack構建時告訴webpack哪些文件已被預編譯,使構建過程忽略這些已預編譯的文件;
具體做法就是在vue.config.js的配置文件中添加
const webpack = require("webpack"); module.exports = { ··· configureWebpack: { plugins: [ new webpack.DllReferencePlugin({ context: process.cwd(), manifest: require("./public/vendor/vendor-manifest.json") }) ] } ··· }
(3) happyPack多線程打包