最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

webpack打包文件体积过大如何解决

来源:动视网 责编:小采 时间:2020-11-27 20:31:35
文档

webpack打包文件体积过大如何解决

webpack打包文件体积过大如何解决:优化对比 : 未优化前:index.html引入一个main.js文件,体积2M以上。 优化后入:index.html引入main.js、commons.js、charts.js、other.js。以达到将main.js平分目的。每个文件控制300k以内.(如果高兴100k也没问题) 用到的一堆库及工具: vu
推荐度:
导读webpack打包文件体积过大如何解决:优化对比 : 未优化前:index.html引入一个main.js文件,体积2M以上。 优化后入:index.html引入main.js、commons.js、charts.js、other.js。以达到将main.js平分目的。每个文件控制300k以内.(如果高兴100k也没问题) 用到的一堆库及工具: vu


  优化对比 :

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

  优化后入:index.html引入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

文档

webpack打包文件体积过大如何解决

webpack打包文件体积过大如何解决:优化对比 : 未优化前:index.html引入一个main.js文件,体积2M以上。 优化后入:index.html引入main.js、commons.js、charts.js、other.js。以达到将main.js平分目的。每个文件控制300k以内.(如果高兴100k也没问题) 用到的一堆库及工具: vu
推荐度:
标签: 文件 文档 打包
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top