淺談webpack性能榨汁機(打包速度優(yōu)化)
最近對項目的本地開發(fā)環(huán)境進行了打包速度優(yōu)化,原有項目,網上能搜到的優(yōu)化方案基本都加了,在16年低配mac pro 上打包時間為25秒多,但我發(fā)現細節(jié)做一些調整可能大大降低打包時間,最終優(yōu)化到7秒多
dll
原有項目是線上和本地公用一套dll配置,因為antd這類ui庫需要按需加載所以不能放到dll中,這時可以單獨寫一個dll配置,將所有第三方庫添加到dll中。
這時因為.babelrc中添加了babel-plugin-import插件會導致優(yōu)化不生效,所以需要對開發(fā)環(huán)境單獨配置babel
options的babelrc設置為false,然后重寫一份babel配置,一定不要添加“import”插件
一個新問題,因為沒有import插件,導致所有antd組件樣式丟失。這時我在index-template.html中加入一行注釋<!-- local-style -->,在本地打包時將其替換為antd相應版本在cdn上的css文件
緩存
cache-loader專治花里胡哨!雖然你能在webpack的配置里找到n種緩存設置,但我發(fā)現cache-loader可以替代其它選項,它會在你的項目中創(chuàng)建一個 .cache-loader的文件夾,里面存放緩存文件,因為是直接寫入硬盤,所以第一次打包的時候會多消耗幾秒
babel-loader & 多線程
上面的圖中可以看到我將babel-loader升級到8+,新的preset和plugin都有了命名上的變化。preset-env是用來替代以前201X的,通過targets可以指定目標代碼(編譯后代碼)的版本,因為是本地開發(fā),可以指定到chrome的高版本,這樣很多新語法都不需要轉換,可以節(jié)省一點時間(打包速度在10秒以下之后減一秒都是10%的提升啊?。┎贿^這個方案要慎重使用,因為會造成線上本地環(huán)境不統(tǒng)一,難保不出現什么神奇的bug
拔掉HappyPack提升性能
在測試的過程中我發(fā)現一個神奇的事情,就是HappyPack反倒會降低打包時間,我經過反復測試,似乎babel-loader8+自帶了多線程優(yōu)化,所以HappyPack已經沒用了(反而因為線程通信造成了資源浪費)。babel-loader8+的cpu使用率以及打包時間和babel-loader6+加HappyPack是相差不多的,但我在google上搜索時并沒有看到有人提及此事,官網也沒看到有個說明(管他那么多呢,能提升速度就行啦!)
后續(xù)計劃
這個項目是兩個人迭代一年份的代碼量,按照上面的配置大部分項目應該都可以優(yōu)化到10秒左右的速度(看項目大小,20秒以下應該都是正常的),還有一些小的優(yōu)化細節(jié)對性能影響不大所以忽略掉了。目前webpack還是3+版本,因為4的一些變化擔心影響過大,暫時沒升級,升級之后應該還會有一些小提速
這7秒還不是最終的速度,我估計5秒應該沒啥問題,后面再想優(yōu)化就需要腦洞大開了
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
javascript常用方法、屬性集合及NodeList 和 HTMLCollection 的瀏覽器差異
對于 HTMLCollection集合對象 必須要說一說的是 namedItem方法. 看看規(guī)范的解釋.2010-12-12Javascript中類式繼承和原型式繼承的實現方法和區(qū)別之處
其它的面向對象程序設計語言都是通過關鍵字來解決繼承的問題。但是javascript中并沒有定義這種實現的機制。接下來通過本文給大家介紹Javascript中類式繼承和原型式繼承的實現方法和區(qū)別,需要的朋友可以參考下2017-04-04javascript 系統(tǒng)文件夾文件操作及參數介紹
javascript文件操作包括寫入文件、當前目錄文件、讀文件、刪除文件、批量刪除,未刪除文件夾,刪除不了當前目錄文件等等,感興趣的朋友可以參考下2013-01-01