美文网首页
webpack 打包优化

webpack 打包优化

作者: yongningfu | 来源:发表于2017-08-06 20:50 被阅读0次

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 3 打包性能优化

    基于webpack 3 打包性能优化 source Scope Hoisting. 过去 webpack 打包时的...

  • webpack打包优化

    实现webpack打包优化,有两个优化点: 如何减少打包时间 如何减少打包大小 减少打包时间 优化Loader对于...

  • React单页面应用项目 性能优化 实践

    react 单页面应用项目在加载优化这一块就得依赖webpack的打包方式。webpack的打包优化的本质就是将 ...

  • 浅谈webpack打包原理

    近来想要对旧项目进行优化,所以了解下webpack打包原理为优化做准备 webpack 4.x 打包文件 inde...

  • Webpack极限打包优化

    今天为了更好地了解一下Webpack打包优化的一些内容,看了一下NEXT公开课,Webpack打包极限优化,感兴趣...

  • Webpack 打包优化之速度篇

    在前文 Webpack 打包优化之体积篇中,对如何减小 Webpack 打包体积,做了些探讨;当然,那些法子对于打...

  • 前端打包部署优化之gzip

    使用webpack打包出来的文件过大,导致访问速度极其慢,搜索webpack打包优化,能够看到很多前辈的建议:gz...

  • webpack 性能优化

    webpack性能优化 开发环境性能优化 生产环境性能优化 开发环境性能优化 优化打包构建速度 优化调试功能 生产...

  • vue项目优化

    vue 项目优化 项目打包体积优化 通常vue项目通过webpack打包后,会出现vendor包的体积过大的情况,...

  • 2019-12-16 总结几个webpack打包优化的方法

    总结几个webpack打包优化的方法 为什么要优化打包? 项目越做越大,依赖包越来越多,打包文件太大 单页面应用首...

网友评论

      本文标题:webpack 打包优化

      本文链接:https://www.haomeiwen.com/subject/dbenlxtx.html