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打包体积上也比之前的小。在项目优化中,可以很大程度上加快项目的构建速度和减少项目的打包体积。