国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

詳解webpack 打包文件體積過大解決方案(code splitting)

2024-05-06 16:43:41
字體:
來源:轉載
供稿:網友

優化對比 :

  未優化前: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 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 腾冲县| 太康县| 澄城县| 平乡县| 长丰县| 龙口市| 泸溪县| 呼图壁县| 广州市| 潍坊市| 湘潭市| 阳曲县| 西丰县| 稷山县| 怀安县| 宁波市| 航空| 商南县| 宜宾市| 克拉玛依市| 蕲春县| 天气| 南漳县| 邯郸县| 临城县| 吕梁市| 成武县| 紫阳县| 北安市| 天气| 当阳市| 沅陵县| 民丰县| 虹口区| 江北区| 济源市| 新绛县| 阿克苏市| 根河市| 淅川县| 宝鸡市|