值得了解的幾個實用JavaScript優化小技巧

2022-03-28 13:02:05
在工作中我們經常可以通過一些小細節來增加程式碼可讀性,讓程式碼看起來更加優雅。本篇文章就來給大家分享幾個一看就會的實用JavaScript優化小技巧,希望對大家有所幫助!

「難度:?」 「推薦閱讀時長:5min

正片

減少if...else麵條程式碼

  • 一旦當我們寫到超過兩個if...else的函數的時候就該想想是否有更好的優化方法。【相關推薦:】
  • 比如現在需要讓我們根據名稱計算出麥某勞的食品價格,你可能會這麼做。

1.png

  • 這樣的寫法會讓函數體有很多的條件判斷語句,而當我們想下次增加一個商品的時候就需要修改函數內的邏輯增加一個if...else語句,這一定程度上也違反了開閉原則,當我們需要增加一個邏輯的時候要儘量通過擴充套件軟體實體來解決需求變化,而不是通過修改已有的程式碼來完成變化。
  • 這是很經典的優化方式,我們可以使用一個類似Map機構的資料來儲存所有商品,這裡我們直接建立一個物件來儲存。

2.png

  • 這樣我們下次需要再增加一個商品時就不需要改動getPrice的邏輯了,當然了這裡其實更多人喜歡直接在用的地方直接使用foodMap,我這裡只是簡單舉了個例子表述這個思路。
  • 那麼這時候就有同學會問了,如果我不想key只用字串呢,這時候你就可以用到new Map了,思路也是差不多的,額外擴充套件一個實體來儲存變化。

管道操作取代冗餘迴圈

  • 有這麼一個麥某勞食物列表

3.png

  • 如果你想找出屬於套餐1的食物,你會怎麼找呢?
  • 上面這種是我們以前經常使用的方法,顯然我們替換成使用filtermap來取代for迴圈不僅可以使程式碼更精簡,還可以使語意更加明確,這樣我們一下就可以看出是先對陣列過濾重組

4.png

find取代冗餘迴圈

  • 還是上面的例子,如果我們要在這個食品物件陣列中按照屬性值查詢特定的食物時,find的用處就出來了。

5.png

includes取代冗餘迴圈

  • 和上面兩個細節類似的這些都是既有的函數也就是不用我們重新寫的內建函數,巧用它會節省很多時間。
  • 眾所周知,一碗康某傅老壇酸菜牛肉麵酸菜牛肉粒菸頭腳皮組成,那我們想用函數證實這個面裡面是否有腳皮我們怎麼寫會比較簡潔呢?

6.png

  • 同樣的,不止是康某傅的酸菜牛肉麵可以這樣耍,所有類似的在陣列裡面找到特定元素的操作都可以使用includes函數來呼叫。

result返回值

  • 我們通常在寫一些擁有返回值的函數的時候常常會以返回值變數命名而糾結,甚至對於一些長函數的時候還不使用變數而是直接return,這樣的習慣其實是不好的,因為等我們下次再去參照這段程式碼的時候還需要重新捋清邏輯。
  • 通常的,在一個小函數中,我們可以使用result作為返回值。

7.png

提前返回

  • 然而上面用result作為返回值並不適用於所有情況,往往有些時候我們需要提前結束函數體來避免後面的同事閱讀多餘的程式。

  • 如下的例子中當我們selectedKey不存在的時候應該立即return,這樣就不用繼續閱讀下面的程式碼,否則面對更復雜的函數時會增加很多的閱讀成本。

8.png

保持物件完整

  • 經常在我們通過請求拿到後端返回的資料會根據其中一些屬性進行處理,如果需要處理的屬性少的時候很多同學會習慣使用第一種方法。
  • 但其實這種習慣是不好的,因為當你無法確定這個函數以後還需不需要增加依賴屬性的時候應該保持物件的完整,就像我上篇文章提到的,學會擁抱變化,假如getDocDetail不止要用到iconcontent,可能以後還會有titledate等屬性,所以我們不如直接將完整物件傳入,不僅增加縮短參數列還會讓程式碼更易讀。

9.png

巧用運運算元

  • 當我們需要建立新變數時, 有時需要檢查為其值參照的變數是否為null或未定義時, 就可以使用簡便寫法。

10.png

寫在最後

  • 首先還是很感謝大家看到這裡,這次的文章就分享到這裡,總結了幾個很基礎的優化方法,希望可以幫到大家。

【相關視訊教學推薦:】

以上就是值得了解的幾個實用JavaScript優化小技巧的詳細內容,更多請關注TW511.COM其它相關文章!