1.修改source-map配置:此配置能大大減小打包後文件體積。javascript
a.首先修改 /config/index.js 文件: html
// /config/index.js dev環境:devtool: 'eval'(最快速度) prod環境:productionSourceMap: false(關閉source-map) b.而後修改 /src/main.js 文件,關閉生產環境的調試信息 // /src/main.js const isDebug_mode = process.env.NODE_ENV !== 'production' Vue.config.debug = isDebug_mode Vue.config.devtools = isDebug_mode Vue.config.productionTip = isDebug_mode
npm install happypack --save-dev // /build/webpack.base.conf.js const HappyPack = require('happypack') const os = require('os') const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length }) // 增長HappyPack插件 plugins: [ new HappyPack({ id: 'happy-babel-js', loaders: ['babel-loader?cacheDirectory=true'], threadPool: happyThreadPool, }) ] // 修改引入loader { test: /\.js$/, // loader: 'babel-loader', loader: 'happypack/loader?id=happy-babel-js', // 增長新的HappyPack構建loader include: [resolve('src'), resolve('test')] }
const path = require("path") const webpack = require("webpack") module.exports = { // 你想要打包的模塊的數組 entry: { vendor: ['vue/dist/vue.esm.js', 'axios', 'vue-router', 'iview'] }, output: { path: path.join(__dirname, '../static/js'), // 打包後文件輸出的位置 filename: '[name].dll.js', library: '[name]_library' }, plugins: [ new webpack.DllPlugin({ path: path.join(__dirname, '.', '[name]-manifest.json'), name: '[name]_library', context: __dirname }), // 壓縮打包的文件 new webpack.optimize.UglifyJsPlugin({ compress: { warnings: false } }) ] }
b. 在 build/webpack.dev.conf.js 和 build/webpack.prod.conf.js 增長以下插件vue
new webpack.DllReferencePlugin({ context: __dirname, manifest: require('./vendor-manifest.json') })
c.在 /package.json 增長命令 java
"dll": "webpack --config ./build/webpack.dll.config.js"
d.在 /index.html 增長DLL化JS引入(必須首先引入)webpack
<script src="/static/js/vendor.dll.js"></script>
e.執行構建ios
npm run dll(這一步會生成build/vendor-manifest.json和static/js/vendor.dll.js) npm run dev 或 npm run build
4.經過 externals
配置來提取經常使用庫,引用外鏈web