您好,登錄后才能下訂單哦!
今天小編給大家分享一下如何實現JavaScript if分支優化的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
最近在網上沖浪時看到了這樣一段代碼:
function getUserDescribe(name) {
if (name === "小劉") {
console.log("劉哥哥");
} else if (name === "小紅") {
console.log("小紅妹妹");
} else if (name === "陳龍") {
console.log("大師");
} else if (name === "李龍") {
console.log("師傅");
} else if (name === "大鵬") {
console.log("惡人");
} else {
console.log("此人比較神秘!");
}
}
咋一看沒感覺有什么異常,但如果有1000個判斷條件,按照這種寫法難不成要寫1000個 if
分支?
如果寫了大量的 if
分支,并且可能還具有分支套分支,可以想象到整個代碼的可讀性和可維護都會大大降低,這在實際開發中,確實是一個比較頭疼的問題,那有沒有什么辦法能夠即實現需求又能避免這些問題呢?
這就涉及到分支優化,讓我們轉換思維,去優化一下上面的代碼結構:
function getUserDescribe(name) {
const describeForNameMap = {
小劉: () => console.log("劉哥哥"),
小紅: () => console.log("小紅妹妹"),
陳龍: () => console.log("大師"),
李龍: () => console.log("師傅"),
大鵬: () => console.log("惡人"),
};
describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比較神秘!");
}
問題代碼中的判斷都是簡單的相等判斷,那么我們就可以將這些判斷條件作為一個屬性寫到對象describeForNameMap
中去,這些屬性對應的值就是條件成立后的處理函數。
之后我們就只需通過getUserDescribe
函數接收到的參數去獲取describeForNameMap
對象中對應的值,如果該值存在就運行該值(因為值是一個函數)。
這樣一來原本的 if
分支判斷就轉換成了簡單的key value
對應值,條件與處理函數一一對應,一目了然。
那如果我們的 if
分支中的判斷條件不只是簡單的相等判斷,還具有一些需要計算的表達式時,我們該怎么辦呢?(如下所示)
function getUserDescribe(name) {
if (name.length > 3) {
console.log("名字太長");
} else if (name.length < 2) {
console.log("名字太短");
} else if (name[0] === "陳") {
console.log("小陳");
} else if (name[0] === "李" && name !== "李鵬") {
console.log("小李");
} else if (name === "李鵬") {
console.log("管理員");
} else {
console.log("此人比較神秘!");
}
}
對于這種結構的代碼就不能引入對象來進行分支優化了,我們可以引入二維數組來進行分支優化:
function getUserDescribe(name) {
const describeForNameMap = [
[
(name) => name.length > 3, // 判斷條件
() => console.log("名字太長") // 執行函數
],
[
(name) => name.length < 2,
() => console.log("名字太短")
],
[
(name) => name[0] === "陳",
() => console.log("小陳")
],
[
(name) => name === "大鵬",
() => console.log("管理員")
],
[
(name) => name[0] === "李" && name !== "李鵬",
() => console.log("小李"),
],
];
// 獲取符合條件的子數組
const getDescribe = describeForNameMap.find((item) => item[0](name));
// 子數組存在則運行子數組中的第二個元素(執行函數)
getDescribe ? getDescribe[1]() : console.log("此人比較神秘!");
}
上面我們定義了一個describeForNameMap
數組,數組內的每一個元素代表一個判斷條件與其執行函數的集合(也是一個數組),之后我們通過數組的find
方法查找describeForNameMap
數組中符合判斷條件的子數組即可。
上面例子中我們定義的這個describeForNameMap
對象是一個獨立的結構,我們完全可以將它抽離出去:
const describeForNameMap = {
小劉: () => console.log("劉哥哥"),
小紅: () => console.log("小紅妹妹"),
陳龍: () => console.log("大師"),
李龍: () => console.log("師傅"),
大鵬: () => console.log("惡人"),
};
function getUserDescribe(name) {
describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比較神秘!");
}
const describeForNameMap = [
[
(name) => name.length > 3, // 判斷條件
() => console.log("名字太長") // 執行函數
],
[
(name) => name.length < 2,
() => console.log("名字太短")
],
[
(name) => name[0] === "陳",
() => console.log("小陳")
],
[
(name) => name === "大鵬",
() => console.log("管理員")
],
[
(name) => name[0] === "李" && name !== "李鵬",
() => console.log("小李"),
],
];
function getUserDescribe(name) {
// 獲取符合條件的子數組
const getDescribe = describeForNameMap.find((item) => item[0](name));
// 子數組存在則運行子數組中的第二個元素(執行函數)
getDescribe ? getDescribe[1]() : console.log("此人比較神秘!");
}
通過模塊化的開發也可以將這個
map
對象寫進一個單獨的js
文件,之后在需要使用的地方導入即可。
這樣一來整個getUserDescribe
函數就變得非常簡潔,有的同學可能會問這有什么用呢?這不是更加麻煩了嗎?如果真的嫌if else
不好看,那我就使用if return
不用else
就好了:
function getUserDescribe(name) {
if (name === "小劉") {
console.log("劉哥哥");
return;
}
if (name === "小紅") {
console.log("小紅妹妹");
return;
}
if (name === "陳龍") {
console.log("大師");
return;
}
if (name === "李龍") {
console.log("師傅");
return;
}
if (name === "大鵬") {
console.log("惡人");
return;
}
console.log("此人比較神秘!");
}
試想一下,如果你getUserDescribe
函數中有1000個判斷分支,并且還具有大量的根據判斷結果來執行的處理代碼,并且getUserDescribe
函數會返回這個處理后的判斷結果的值。
這時getUserDescribe
函數的重點在于對判斷結果的處理,而不在于這個結果是通過什么分支獲取的,例如:
function getUserDescribe(name) {
let str; // 存儲判斷結果
if (name.length > 3) {
str = "名字太長";
} else if (name.length < 2) {
str = "名字太短";
} else if (name[0] === "陳") {
str = "小陳";
} else if (name[0] === "李" && name !== "李鵬") {
str = "小李";
} else if (name === "李鵬") {
str = "管理員";
} else {
str = "此人比較神秘!";
}
// 對判斷結果str的一些處理
// ......
console.log(str);
return str;
}
如果你不進行分支優化,getUserDescribe
函數就會被大量的 if
分支搶占空間,使得getUserDescribe
函數的重點迷失(getUserDescribe
函數重點在于對判斷結果的處理,而不在于這個結果是通過什么分支獲取的),這時你再看一下我們優化后的代碼:
const describeForNameMap = [
[(name) => name.length > 3, () => "名字太長"],
[(name) => name.length < 2, () => "名字太短"],
[(name) => name[0] === "陳", () => "小陳"],
[(name) => name === "大鵬", () => "管理員"],
[(name) => name[0] === "李" && name !== "李鵬", () => "小李"],
];
function getUserDescribe(name) {
let str; // 存儲判斷結果
const getDescribe = describeForNameMap.find((item) => item[0](name));
if (getDescribe) {
str = getDescribe[1]();
} else {
str = "此人比較神秘!";
}
// 對判斷結果str的一些處理
// ......
console.log(str);
return str;
}
查看優化后的getUserDescribe
函數我們能夠知道,它從describeForNameMap
獲取了一個值賦值給了str
(describeForNameMap
是如何返回值的我們并不關心),之后對str
作了一些處理。這就突出了getUserDescribe
函數的重點(對判斷結果str進行處理)。
在這個例子中
describeForNameMap
子數組的第二個元素完全可以直接使用一個值:[(name) => name.length > 3, "名字太長"]
,但為了整體代碼的可擴展性,推薦還是使用函數,因為函數可以接收參數,方便應對之后更復雜的場景。
以上就是“如何實現JavaScript if分支優化”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。