webpack实践之DLLPlugin 和 DLLReferencePlugin的使用教程
DLLPlugin和DLLReferencePlugin的使用
DLLPlugin和DLLReferencePlugin用某种方法实现了拆分bundles,同时还大大提升了构建的速度。
1.首先build文件夹添加----webpack.dll.config.js:
varpath=require("path");
varwebpack=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:[
newwebpack.DllPlugin({
path:path.join(__dirname,'.','[name]-manifest.json'),
name:'[name]_library',
context:__dirname
}),
]
};
2.在package.json的scripts里加上:
"dll":"webpack--configbuild/webpack.dll.config.js",
3.运行npmrundll在static/js下生成vendor-manifest.json;
4.在build/webpack.base.conf.js里加上:
//添加DllReferencePlugin插件
plugins:[
newwebpack.DllReferencePlugin({
context:__dirname,
manifest:require('./vendor-manifest.json')
})
],
5.然后在index.html中引入vendor.dll.js:
至此,配置之后的:
可以看到npmrunbuild后的时间大幅度减少,在dist打包体积上也比之前的小。在项目优化中,可以很大程度上加快项目的构建速度和减少项目的打包体积。
总结
以上所述是小编给大家介绍的webpack实践之DLLPlugin和DLLReferencePlugin的使用教程,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!