webpack实践之DLLPlugin 和 DLLReferencePlugin

DLLPlugin 和 DLLReferencePlugin的使用

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

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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
   }),
  ]
};

2.在package.json的scripts里加上:

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

3.运行npm run dll 在static/js下生成vendor-manifest.json;

 4.在build/webpack.base.conf.js里加上:

1
2
3
4
5
6
7
// 添加DllReferencePlugin插件
  plugins: [
   new webpack.DllReferencePlugin({
    context: __dirname,
    manifest: require( './vendor-manifest.json' )
   })
  ],

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

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

至此,配置之后的:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值