当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 详解webpack 打包文件体积过大解决方案(code splitting)

详解webpack 打包文件体积过大解决方案(code splitting)

2018年04月28日  | 移动技术网IT编程  | 我要评论

优化对比 :

  未优化前:引入一个main.js文件,体积2m以上。

  优化后入:引入main.js、commons.js、charts.js、other.js。以达到将main.js平分目的。每个文件控制300k以内.(如果高兴100k也没问题)

用到的一堆库及工具:

vue、webpack、babel、highcharts、echarts、jquery、html2canvas******此去省略若干m代码

问题:

  开发环境用webpack后发现单个js文件5m。

  生产环境借助vue-cli的webpack配置,减少到2m。

解决方案:

  搜索各种解决方案:require.ensure、require依赖、多entry、commonschunkplugin****此去省力若干方案

网络类似下边这种上解决方案太多了,但是都达不到预期效果

entry:{ 
 main:'xxx.js',
  chunks:['c1', 'c2'],
  commons:['jquery', 'highcharts', 'echarts','d3', 'xxxxx.js']  
}

 

plugins:{
new commonschunkplugin({
name:'commons',
minchunks:2
})  
}

最优解决方案:

entry:{ 
 main:'xxx.js'
}
 
plugins:{
 new commonschunkplugin({
 name:'commons',
 minchunks:function(module){
  // 下边return参考的vue-cli配置
  // any required modules inside node_modules are extracted to vendor
  return (
   module.resource &&
   /\.js$/.test(module.resource) &&
   module.resource.indexof(
   path.join(__dirname, '../node_modules')
   ) === 0
  )
 }
}) ,
// 以下才是关键
new commonschunkplugin({
 name:'charts',
 chunks:['commons'] 
 minchunks:function(module){
  return (
   module.resource &&
   /\.js$/.test(module.resource) &&
   module.resource.indexof(
   path.join(__dirname, '../node_modules')
   ) === 0 && ['jquery.js', 'highcharts.js','echarts'].indexof( module.resource.substr(module.resource.lastindexof('/')+1).tolowercase() ) != -1
  )
 }
}) // 如果愿意,可以再new 一个commonschunkplugin
 
}

以上代码打包出来的结果:main.js 、commons.js、charts.js 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网