值得了解的幾個實用JavaScript優化小技巧
在工作中我們經常可以透過一些小細節來增加程式碼可讀性,讓程式碼看起來更優雅。這篇文章就來跟大家分享幾個一看就會的實用JavaScript優化小技巧,希望對大家有幫助!
「難度:?」 「推薦閱讀時間:5min
」
正片
減少if...else麵條程式碼
- 一旦當我們寫到超過兩個
if ...else
的函數的時候就該想想是否有更好的最佳化方法。 【相關推薦:javascript學習教學】 - 例如現在需要讓我們根據名稱計算麥某勞的食品價格,你可能會這麼做。
- 這樣的寫法會讓函數體有很多的條件判斷語句,而當我們想下次增加一個商品的時候就需要修改函數內的邏輯增加一個
if...else
語句,這一定程度上也違反了開閉原則,當我們需要增加一個邏輯的時候要盡量透過擴展軟體實體來解決需求變化,而不是透過修改現有的程式碼來完成變更。 - 這是很經典的最佳化方式,我們可以使用一個類似
Map
機構的資料來保存所有商品,這裡我們直接建立一個物件來儲存。
- 這樣我們下次需要再增加一個商品時就不需要改動
getPrice
的邏輯了,當然了這裡其實更多人喜歡直接在用的地方直接使用foodMap
,我這裡只是簡單舉了個例子表達這個想法。 - 那麼這時候就有同學會問了,如果我不想
key
只用字串呢,這時候你就可以用到new Map
了,思路也是差不多的,額外擴充一個實體來儲存變化。
管道操作取代冗餘循環
- 有這麼一個麥某勞食物清單
- 如果你想找出屬於套餐1的食物,你會怎麼找呢?
- 上面這種是我們以前經常使用的方法,顯然我們替換成使用
filter
與map
來取代for
循環不僅可以使程式碼更精簡,還可以讓語意更加明確,這樣我們一下就可以看出是先對數組過濾
再重組
。
find取代冗餘循環
- 還是上面的例子,如果我們要在這個食品對象數組中依照屬性值找出特定的食物時,
find
的用處就出來了。
includes取代冗餘循環
- 和這些上面兩個細節類似的都是既有的函數也就是不用我們重新寫的內建函數,巧用它會節省很多時間。
- 眾所周知,一碗康某傅老壇酸菜牛肉麵有酸菜,面,牛肉粒, 煙頭和腳皮組成,那我們想用函數來確認這個面裡面有沒有腳皮我們怎麼寫會比較簡潔呢?
- 同樣的,不只康某傅的酸菜牛肉麵可以這樣耍,所有類似的在陣列裡面找到特定元素的運算都可以使用
includes
函數來呼叫。
result傳回值
- 我們通常在寫一些擁有傳回值的函數的時候常常會以傳回值變數命名而糾結,甚至對於一些長函數的時候還不使用變數而是直接
return
,這樣的習慣其實是不好的,因為等我們下次再去參照這段程式碼的時候還需要重新捋清邏輯。 - 通常的,在一個小函數中,我們可以使用
result
作為回傳值。
提前回傳
然而上面用
result
作為回傳值並不適用於所有情況,往往有些時候我們需要提前結束函數體來避免後面的同事閱讀多餘的程式。如下的例子中當我們
selectedKey
不存在的時候應該立即return
,這樣就不用繼續閱讀下面的程式碼,否則面對更複雜的函數時會增加很多的閱讀成本。
保持物件完整
- #經常在我們透過請求拿到後端回傳的資料會根據其中一些屬性來處理,如果需要處理的屬性少的時候很多同學會習慣使用第一種方法。
- 但其實這種習慣是不好的,因為當你無法確定這個函數以後還需不需要增加依賴屬性的時候應該保持物件的完整,就像我上篇文章提到的,學會擁抱變化,假如
getDocDetail
不只用到icon
和content
,可能以後還會有title
,date
等屬性,所以我們不如直接將完整物件傳入,不僅增加縮短參數清單還會讓程式碼更容易閱讀。
巧用運算子
- 當我們需要建立新變數時, 有時需要檢查為其值引用的變數是否為
null
或未定義時, 就可以使用簡單寫法。
寫在最後
- 首先還是很感謝大家看到這裡,這次的文章就分享到這裡,總結了幾個很基本的優化方法,希望可以幫到大家。
【相關影片教學推薦:web前端】
以上是值得了解的幾個實用JavaScript優化小技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

解碼Laravel效能瓶頸:優化技巧全面揭秘! Laravel作為一個受歡迎的PHP框架,為開發者提供了豐富的功能和便利的開發體驗。然而,隨著專案規模增加和訪問量增加,我們可能會面臨效能瓶頸的挑戰。本文將深入探討Laravel效能最佳化的技巧,幫助開發者發現並解決潛在的效能問題。一、資料庫查詢優化使用Eloquent延遲載入在使用Eloquent查詢資料庫時,避免

Laravel是一款廣受歡迎的PHP開發框架,但有時候被人詬病的就是其速度慢如蝸牛。究竟是什麼原因導致了Laravel的速度不盡人意呢?本文將從多個面向深入解讀Laravel速度慢如蝸牛的原因,並結合具體的程式碼範例,幫助讀者更深入地了解此問題。 1.ORM查詢效能問題在Laravel中,ORM(物件關係映射)是一個非常強大的功能,可以讓

時間複雜度衡量演算法執行時間與輸入規模的關係。降低C++程式時間複雜度的技巧包括:選擇合適的容器(如vector、list)以最佳化資料儲存和管理。利用高效演算法(如快速排序)以減少計算時間。消除多重運算以減少重複計算。利用條件分支以避免不必要的計算。透過使用更快的演算法(如二分搜尋)來優化線性搜尋。

Golang的垃圾回收(GC)一直是開發者關注的熱門話題。 Golang作為一門快速的程式語言,其自帶的垃圾回收器能夠很好地管理內存,但隨著程式規模的增大,有時會出現一些效能問題。本文將探討Golang的GC最佳化策略,並提供一些具體的程式碼範例。 Golang中的垃圾回收Golang的垃圾回收器採用的是基於並發標記-清除(concurrentmark-s

Laravel效能瓶頸揭秘:優化方案大揭秘!隨著網路技術的發展,網站和應用程式的效能優化變得愈發重要。作為一款流行的PHP框架,Laravel在開發過程中可能會面臨效能瓶頸。本文將探討Laravel應用程式可能遇到的效能問題,並提供一些最佳化方案和具體的程式碼範例,讓開發者能夠更好地解決這些問題。一、資料庫查詢最佳化資料庫查詢是Web應用中常見的效能瓶頸之一。在

1.在桌面上按組合鍵(win鍵+R)開啟運行窗口,接著輸入【regedit】,回車確認。 2.開啟登錄編輯程式後,我們依序點選展開【HKEY_CURRENT_USERSoftwareMicrosoftWindowsCurrentVersionExplorer】,然後看目錄裡有沒有Serialize項,如果沒有我們可以點選右鍵Explorer,新建項,並將其命名為Serialize。 3.接著點選Serialize,然後在右邊窗格空白處點選滑鼠右鍵,新建一個DWORD(32)位元值,並將其命名為Star

PHP函數效率最佳化的五大方法:避免不必要的變數複製。使用引用以避免變數複製。避免重複函數呼叫。內聯簡單的函數。使用數組優化循環。

Vivox100s參數配置大揭密:處理器效能如何最佳化?在當今科技快速發展的時代,智慧型手機已經成為我們日常生活不可或缺的一部分。作為智慧型手機的重要組成部分,處理器的效能優化直接關係到手機的使用體驗。 Vivox100s作為一款備受矚目的智慧型手機,其參數配置備受關注,尤其是處理器效能的最佳化議題更是備受用戶關注。處理器作為手機的“大腦”,直接影響手機的運行速度
