当前位置:Gxlcms > JavaScript > webpack打包文件体积超大解决思路

webpack打包文件体积超大解决思路

时间:2021-07-01 10:21:17 帮助过:27人阅读

这次给大家带来webpack打包文件体积超大解决思路,解决webpack打包文件体积超大的注意事项有哪些,下面就是实战案例,一起来看一下。

优化对比 :

  未优化前: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****此去省力若干方案

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

  1. entry:{
  2. main:'xxx.js',
  3. chunks:['c1', 'c2'],
  4. commons:['jquery', 'highcharts', 'echarts','d3', 'xxxxx.js']
  5. }
  6. plugins:{
  7. new commonsChunkPlugin({
  8. name:'commons',
  9. minChunks:2
  10. })
  11. }

最优解决方案:

  1. entry:{
  2. main:'xxx.js'
  3. }
  4. plugins:{
  5. new commonsChunkPlugin({
  6. name:'commons',
  7. minChunks:function(module){
  8. // 下边return参考的vue-cli配置
  9. // any required modules inside node_modules are extracted to vendor
  10. return (
  11. module.resource &&
  12. /\.js$/.test(module.resource) &&
  13. module.resource.indexOf(
  14. path.join(dirname, '../node_modules')
  15. ) === 0
  16. )
  17. }
  18. }) ,
  19. // 以下才是关键
  20. new commonsChunkPlugin({
  21. name:'charts',
  22. chunks:['commons']
  23. minChunks:function(module){
  24. return (
  25. module.resource &&
  26. /\.js$/.test(module.resource) &&
  27. module.resource.indexOf(
  28. path.join(dirname, '../node_modules')
  29. ) === 0 && ['jquery.js', 'highcharts.js','echarts'].indexOf( module.resource.substr(module.resource.lastIndexOf('/')+1).toLowerCase() ) != -1
  30. )
  31. }
  32. }) // 如果愿意,可以再new 一个commonsChunkPlugin
  33. }

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

JS对图片进行黑白化设置

vue select组件开启与禁用方法详解

以上就是webpack打包文件体积超大解决思路的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行