首页 > 编程 > JavaScript > 正文

webpack实践之DLLPlugin 和 DLLReferencePlugin的使用教程

2019-11-19 11:21:45
字体:
来源:转载
供稿:网友

DLLPlugin 和 DLLReferencePlugin的使用

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

1.首先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  }), ]};

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里加上:

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

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

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

至此,配置之后的:

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

总结

以上所述是小编给大家介绍的webpack实践之DLLPlugin 和 DLLReferencePlugin的使用教程,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表