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

最新文章

  1. webSocket and LKDBHelper的使用说明
  2. C语言 &#183; 求矩阵各个元素的和
  3. 你好,欢迎来到我的博客,我是博主royalmice1
  4. SVN中trunk、branches、tags用法详解
  5. bzoj 1951 [Sdoi2010]古代猪文(数论知识)
  6. 关于VerilogHDL生成的锁存器
  7. php强制下载文件并显示原始文件名
  8. 音乐API
  9. mysql触发器new和old
  10. 远程连接你的linux服务器
  11. EasyUI combogrid/combobox过滤时限制只能选择现有项
  12. 使用Docker镜像
  13. Hadoop 系列(一)基本概念
  14. js 和 css 中 不能使用 jsp 页面中一些 标签 和 java 代码等,应注意
  15. android toast使用方法
  16. kafka可靠性
  17. ZOJ 3630 Information 强连通
  18. Apache Tez 了解
  19. StringBuilder String string.Concat 字符串拼接速度
  20. php写入、追加写入文件的实例

热门文章

  1. JPA进行insert操作时会首先select吗
  2. window 系统下修改`CMD`的编码格式的方法,`CHCP` 的 使用
  3. 【js】vue 2.5.1 源码学习 (七) 初始化之 initState 响应式系统基本思路
  4. Fast Stone截图工具使用教程
  5. 【23.26%】【codeforces 747D】Winter Is Coming
  6. Linux 内核总线
  7. 文本框(代替input)输入长度限制、提示
  8. js 处理json
  9. ES6类的继承
  10. 修改Samba密码后无法登录