中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-04 15:40:19 來源:腳本之家 閱讀:307 作者:懦酷 欄目:web開發

優化對比 :

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乐安县| 屯门区| 饶阳县| 大埔县| 澄江县| 嘉荫县| 津南区| 建阳市| 怀远县| 中西区| 开封市| 克东县| 马龙县| 响水县| 贵定县| 泰安市| 永登县| 罗江县| 平谷区| 溧水县| 延津县| 宣恩县| 潼南县| 赤水市| 黔西县| 子长县| 元朗区| 阜康市| 乡城县| 东兴市| 宿州市| 明水县| 阿克苏市| 浪卡子县| 石泉县| 莱西市| 岳西县| 米脂县| 石台县| 龙里县| 右玉县|