您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

打包文件体积过大如何处理

2024/2/24 20:50:31发布16次查看
这次给大家带来打包文件体积过大如何处理,打包文件体积太大处理的注意事项有哪些,下面就是实战案例,一起来看一下。
优化对比 :
未优化前: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 }
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue组件做出无限级多选菜单
mac内安装nodejs、npm与cnpm
以上就是打包文件体积过大如何处理的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product