JavaScript如何優(yōu)化邏輯判斷代碼詳解
前言
我們?nèi)粘J褂玫降倪壿嬇袛嗾Z(yǔ)句有 if...else...、switch...case...、do...while...等。
在簡(jiǎn)單場(chǎng)景下,我們可能對(duì)這些語(yǔ)法的性能沒有什么感覺,但當(dāng)遇到復(fù)雜的業(yè)務(wù)場(chǎng)景時(shí),如果處理不善,就會(huì)出現(xiàn)大量的邏輯嵌套,可讀性差并且難以擴(kuò)展。
千里之行始于足下,編寫高可維護(hù)性和高質(zhì)量的代碼,我們就需要從細(xì)節(jié)處入手,我們今天主要討論 JavaScript 中如何優(yōu)化邏輯判斷代碼。
嵌套層級(jí)優(yōu)化
function supply(fruit, quantity) { const redFruits = ['apple', 'strawberry', 'cherry', 'cranberries']; // 條件 1: 水果存在 if (fruit) { // 條件 2: 屬于紅色水果 if (redFruits.includes(fruit)) { console.log('紅色水果'); // 條件 3: 水果數(shù)量大于 10 個(gè) if (quantity > 10) { console.log('數(shù)量大于 10 個(gè)'); } } } else { throw new Error('沒有水果啦!'); } }
通過上面這個(gè)例子,我們可以看到:判斷流程中規(guī)中矩,符合現(xiàn)實(shí)世界的映射。但是,因代碼層層嵌套,導(dǎo)致閱讀和維護(hù)都存在困難。
如果傳入了 fruit 參數(shù),則每次執(zhí)行都至少需要經(jīng)過兩步 if 判斷,在性能上也存在問題。
我們來對(duì)上面的代碼進(jìn)行一下優(yōu)化處理:
function supply(fruit, quantity) { const redFruits = ['apple', 'strawberry', 'cherry', 'cranberries']; if (!fruit) throw new Error('沒有水果啦'); // 條件 1: 當(dāng) fruit 無效時(shí),提前處理錯(cuò)誤 if (!redFruits.includes(fruit)) return; // 條件 2: 當(dāng)不是紅色水果時(shí),提前 return console.log('紅色水果'); // 條件 3: 水果數(shù)量大于 10 個(gè) if (quantity > 10) { console.log('數(shù)量大于 10 個(gè)'); } }
這里主要對(duì)嵌套層級(jí)做了優(yōu)化,提前終止掉了不符合的條件,將三層嵌套減少到了一層,簡(jiǎn)化了代碼結(jié)果結(jié)構(gòu),增強(qiáng)了可閱讀性。
多條件分支的優(yōu)化
相信我們很多人對(duì)下面這種代碼不陌生吧?(想想剛開始寫代碼那會(huì)?。?/p>
function pick(color) { // 根據(jù)顏色選擇水果 if (color === 'red') { return ['apple', 'strawberry']; } else if (color === 'yellow') { return ['banana', 'pineapple']; } else if (color === 'purple') { return ['grape', 'plum']; } else { return []; } }
我們需要知道一點(diǎn)原則:if else 更適合于條件區(qū)間判斷,而 switch case 更適合于具體枚舉值的分支判斷。
我們使用 switch...case...進(jìn)行一下改寫:
function pick(color) { // 根據(jù)顏色選擇水果 switch (color) { case 'red': return ['apple', 'strawberry']; case 'yellow': return ['banana', 'pineapple']; case 'purple': return ['grape', 'plum']; default: return []; } }
switch...case... 優(yōu)化之后的代碼看上去格式整齊,思路很清晰,但還是很冗長(zhǎng)。繼續(xù)優(yōu)化:
借助 Object 的 {key: value} 結(jié)構(gòu),我們可以在 Object 中枚舉所有的情況,然后將 key 作為索引,直接通過 Object.key 或者 Object[key] 來獲取內(nèi)容:
const fruitColor = { red: ['apple', 'strawberry'], yellow: ['banana', 'pineapple'], purple: ['grape', 'plum'], } function pick(color) { return fruitColor[color] || []; }
使用 Map 數(shù)據(jù)結(jié)構(gòu),真正的(key, value) 鍵值對(duì)結(jié)構(gòu):
const fruitColor = new Map() .set('red', ['apple', 'strawberry']) .set('yellow', ['banana', 'pineapple']) .set('purple', ['grape', 'plum']); function pick(color) { return fruitColor.get(color) || []; }
優(yōu)化之后,代碼更簡(jiǎn)潔、更容易擴(kuò)展。
為了更好的可讀性,還可以通過更加語(yǔ)義化的方式定義對(duì)象,然后使用 Array.filter 達(dá)到同樣的效果:
const fruits = [ {name: 'apple', color: 'red'}, {name: 'strawberry', color: 'red'}, {name: 'banana', color: 'yellow'}, {name: 'pineapple', color: 'yellow'}, {name: 'grape', color: 'purple'}, {name: 'plum', color: 'purple'} ]; function pick(color) { return fruits.filter(f => f.color == color); }
總結(jié)
上面使用的例子和手段都比較初級(jí),但是其中的思想?yún)s值得我們細(xì)品,希望大家能夠有所收獲!
到此這篇關(guān)于JavaScript如何優(yōu)化邏輯判斷代碼的文章就介紹到這了,更多相關(guān)JavaScript優(yōu)化邏輯判斷代碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS中改變this指向的方法(call和apply、bind)
this是javascript的一個(gè)關(guān)鍵字,隨著函數(shù)使用場(chǎng)合不同,this的值會(huì)發(fā)生變化。但是總有一個(gè)原則,那就是this指的是調(diào)用函數(shù)的那個(gè)對(duì)象,通過本文給大家介紹JS中改變this指向的方法(call和apply、bind),需要的朋友參考下2016-03-03JavaScript中使用參數(shù)個(gè)數(shù)實(shí)現(xiàn)重載功能
這篇文章主要介紹了JavaScript中使用參數(shù)個(gè)數(shù)實(shí)現(xiàn)重載功能,需要的朋友可以參考下2017-09-09JavaScript獲取GridView選擇的行內(nèi)容
一般GridView第一列是多選框CheckBox,負(fù)責(zé)標(biāo)記當(dāng)前行是否被選中,后面可以有文本框TextBox,下拉框DropDownList,標(biāo)簽Lable2009-04-04原生JS實(shí)現(xiàn)的放大鏡特效示例【測(cè)試可用】
這篇文章主要介紹了原生JS實(shí)現(xiàn)的放大鏡特效,涉及javascript事件響應(yīng)及頁(yè)面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-12-12Javascript 中的 call 和 apply使用介紹
JavaScript 中通過call或者apply用來代替另一個(gè)對(duì)象調(diào)用一個(gè)方法,將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象2012-02-02nodejs讀取本地中文json文件出現(xiàn)亂碼解決方法
在本篇文章中我們給大家分享了關(guān)于nodejs讀取本地中文json文件出現(xiàn)亂碼的解決方法,需要的朋友們可以學(xué)習(xí)下。2018-10-10javascript tips提示框組件實(shí)現(xiàn)代碼
一個(gè)簡(jiǎn)單的類似title的提示效果,但現(xiàn)實(shí)內(nèi)容可以很豐富,以上js另存為tip.js,下面是使用的demo。2010-11-11JS 使用 window對(duì)象的print方法實(shí)現(xiàn)分頁(yè)打印功能
這篇文章主要介紹了JS 使用 window對(duì)象的print方法實(shí)現(xiàn)分頁(yè)打印功能,這種方法兼容性比較好,在ie和火狐瀏覽器下都可以正常使用,感興趣的朋友跟隨腳本之家小編一起看看吧2018-05-05