webpack 打包优化

webpack里面有thunk和module概念,thunk对应的是文件级别的, webpack代码拆分中,很容易出现的问题就是,同一个模块打包到多个thunk文件上面,thunk打包的成一个文件的原理是根据 依赖模块不同抽分成一个thunk, 相关的依赖关系,不重复打包thunk
比如

webpack.ensure() {
  require('./lib1.js')
  require('./lib2.js')
  require('./lib3.js')
}

webpack.ensure() {
  require('./lib1.js')
  require('./lib2.js')
  require('./lib4.js')
}

上面会打包成两个thunk , 第一个thunk里面包含 lib1和lib2, lib3 , 第二个thunk里面包含了lib1和lib2, lib4, 即lib1, lib2重复打包了。

既然重复打包了,那我们得考虑如何在代码切分中,把lib1 和 lib2拆分出来,行成一个文件, 避免重复打包. 之前提供, webpack thunk是根据 依赖的关系决定thunk的,也就是说,如果thunk依赖相同,那么就不会重复打包thunk

webpack.ensure() {
  require('./lib1.js')
  require('./lib2.js')

  webpack.ensure([], () => {
    require('./lib3.js')
  })
  
}


webpack.ensure() {
  require('./lib1.js')
  require('./lib2.js')

  webpack.ensure([], () => {
    require('./lib4.js')
  })
}

上面的话,实际会打包出三个 thunk文件,第一含有 lib1 和 lib2 其他 两个分别含 lib3 和 lib4。异步下载代码的时候,会先下载 含有lib1和lib2的 thunk, 然后下载lib3或者lib4的thunk, 最后执行我们的业务代码,这样的话,就不存在重复打包的文件了。

还有更好的么

上面的代码其实很不优雅, 层层嵌套webpack.ensure 不是一个好方案,对代码维护来说,更加如此。其实我们可以利用promise, 对异步的库进行一层封装

thunk.js

var resolve;
var reject;
var promise = new Promise((res, rej) => {
  resolve = res;
  reject = rej;
});

require.ensure([], (require) => {
  var lib2 = require('./lib2.js');
  resolve(lib2);
});

module.exports = promise;

使用

require('./thunk.js').then((lib2) => {
  console.log(lib2);
})

这样的话,把异步库单独放在一个js文件夹,通过返回一个promise来进行异步获取,而且根据模块机制,对promise对象进行缓存,即一旦第一次导入了这个库,以后都会从缓存中获取。
ps: webpack 2.0其实已经实现了 import 异步库的功能,具体可以查看文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • webpack是react项目标配的打包工具,和NPM搭配起来使用管理模块实在非常方便。  webapck 把所有...
    可乐爱上咖啡阅读 6,534评论 3 51
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,715评论 7 110
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,324评论 4 31
  • 那时候时光正好,我们还不畏惧衰老,每天认真洗脸,多读书,按时睡觉,少食多餐。变得温柔、大度,继续善...
    有脾气的徐小阳阅读 337评论 0 0
  • 今早,定居在广州的舅妈给我打了个电话,约我出去吃饭,还在睡意中的我很欣然的就答应了。中午赶到饭店后,舅妈就和我拉起...
    德儿理阅读 344评论 1 0