首頁 > web前端 > js教程 > webpack 打包檔案體積過大如何解決

webpack 打包檔案體積過大如何解決

伊谢尔伦
發布: 2016-11-21 11:58:14
原創
1425 人瀏覽過

  優化對比 :

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板