這次帶給大家如何處理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 }
以上是如何處理webpack打包體積大文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!