webpack实践——DLLPlugin 和 DLLReferencePlugin的使用

webpack文档中写到:

DLLPlugin 和 DLLReferencePlugin 用某种方法实现了拆分 bundles,同时还大大提升了构建的速度。

首先build文件夹添加----webpack.dll.config.js:

var path = require("path");
var webpack = require("webpack");

module.exports = {
  // 要打包的模块的数组
  entry: {
    vendor: ['vue/dist/vue.esm.js','vue-router']
  },
  output: {
    path: path.join(__dirname, '../static/js'), // 打包后文件输出的位置
    filename: '[name].dll.js',// vendor.dll.js中暴露出的全局变量名。
    library: '[name]_library' // 与webpack.DllPlugin中的`name: '[name]_library',`保持一致。
  },
  plugins: [
    new webpack.DllPlugin({
      path: path.join(__dirname, '.', '[name]-manifest.json'),
      name: '[name]_library', 
      context: __dirname
    }),
  ]
};

在package.json的scripts里加上:

"dll": "webpack --config build/webpack.dll.config.js",

运行npm run dll 在static/js下生成vendor-manifest.json;
在build/webpack.base.conf.js里加上:

// 添加DllReferencePlugin插件
  plugins: [
    new webpack.DllReferencePlugin({
      context: __dirname,
      manifest: require('./vendor-manifest.json')
    })
  ],

然后在index.html中引入vendor.dll.js:

<div id="app"></div>
<script src="./static/js/vendor.dll.js"></script>

看下效果,配置之前:

webpack实践——DLLPlugin 和 DLLReferencePlugin的使用

配置之后的:
webpack实践——DLLPlugin 和 DLLReferencePlugin的使用

可以看到npm run build后的时间大幅度减少,在dist打包体积上也有之前的543kb——到现在的377kb。在项目优化中,可以很大程度上加快项目的构建速度和减少项目的打包体积。

参考文档:​​https://doc.webpack-china.org...
参考好文:Webpack 打包优化之体积篇

相关推荐