首页 > 代码库 > webpack 打包文件体积过大解决方案(code splitting)
webpack 打包文件体积过大解决方案(code splitting)
优化对比 :
未优化前: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 打包文件体积过大解决方案(code splitting)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。