首頁 >web前端 >js教程 >如何處理webpack打包體積大文件

如何處理webpack打包體積大文件

php中世界最好的语言
php中世界最好的语言原創
2018-05-25 14:27:341817瀏覽

這次帶給大家如何處理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****此去省力若干方案

網路類似下邊這種上解決方案太多了,但是都達不到預期效果

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
 
}
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue的select內建元件使用步驟詳解

React使用時避免重渲染

以上是如何處理webpack打包體積大文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn