js的條件表達式和其他語言一樣,都采用了if else和switch這兩種。由於不同的浏覽器對流程控制進行了不同的優化。因此這兩種在性能上是沒有什麼區別的,主要還是根據需求進行分析和選擇。
如果條件較小的話選用if else比較合適。
相反,條件數量較大的話,就建議選用switch。
一般來說,if else適用於兩個離散的值或者不同的值域。如果判斷多個離散值,使用switch更加合適。
在大多數的情況下switch比if else運行的更加快。
恰當的使用 if 與 switch
當我們使用到條件表達式的時候,無論if else還是switch,都應確保下面3哥目標的基本實現:
精確表現事物的內在、固有的邏輯關系。不能為了結構而破壞。
優化邏輯的執行效率。執行效率是程序設計的重要目標,不能為了省事而隨意的消耗資源。
簡化代碼的結構層次,使代碼更加容易的閱讀。
適合使用if else的情況:
具有復雜的邏輯關系。
表達式的值具有線性特征,如對連續的區間值進行判斷。
表達式的值是動態的。
測試任意類型的數據。
適合使用switch的情況:
每句表達式的值。這種是可以期望的、平行邏輯關系的。
表達式的值具有離散性,不具有線性的非連續的區間值。
表達式的值是固定的,不是動態變化的。
表達式的值是有限的,而不是無限的,一般情況下表達式應該比較少。
表達式的值一般為整數、字符串類型的數據。
例如,對學生的分數進行不同的判斷,這個時候使用if else就比較合適,因為這種情況,表達式的值是連續的線性判斷。
if (socre < 60) {
alert('不及格');
} else if (socre > 60 && socre <= 85) {
alert('良好');
} else if (socre > 86) {
alert('優秀');
}
而判斷性別之類的使用switch就比較合適。
switch (sex) {
case '男':
alert('先生');
break;
case '女':
alert('女士');
break;
}
優化 if 邏輯
邏輯順序體現了人的思維的條理和嚴密性。合理的順序可以提升解決問題的品質,相反,混亂的順序和容易導致各種錯誤的發生。
人們考慮的東西到時候,都會把最可能發生的情況先做好准備。優化if邏輯的時候也可以這樣想:把最可能出現的條件放在前面,把最不可能出現的條件放在後面,這樣程序執行時總會按照帶啊名的先後順序逐一檢測所有的條件,知道發現匹配的條件才會停止繼續檢測。
if的優化目標:最小化找到分支之前所判斷條件體的數量。if優化的方法:將最常見的條件放在首位。
if (i < 5) {
// 執行一些代碼
} else if (i > 5 && i < 10) {
// 執行一些代碼
} else {
// 執行一些代碼
}
例如上面這個例子,只有在i值經常出現小於5的時候是最優化的。如果i值經常大於或者等於10的話,那麼在進入正確的分支之前,就必須兩次運算條件體,導致表達式的平均運算時間增加。if中的條件體應該總是按照從最大概率到最小概率排列,以保證理論速度最快。
if 嵌套的思維陷阱
在if語句裡面在嵌套一個if語句是一件經常見到的東西,假設有4個調價你,只有當這些條件都符合要求的時候,才會執行某一些事情。遵循一般人的思維習慣,在檢測這些條件的時候,常常會沿用下面這種結構嵌套:
if (a) {
if (b) {
if (c) {
if (d) {
alert('條件全部成立');
} else {
alert('條件 d 不成立');
}
} else {
alert('條件 c 不成立');
}
} else {
alert('條件 b 不成立');
}
} else {
alert('條件 a 不成立');
}
從思維的方向性來考慮,這種結構並沒有錯,使用下面這種if結構來表示可能更加的合適和簡單:
if (a && b && c && d) {
alert('全部條件成立');
}
從剛才的代碼來說,使用if語句來逐個驗證條件的合法性,並且對某個條件是否合法進行了提示,方便我們去追蹤每一個條件。但是,如果使用了上面的if結構多重嵌套,就會出現另一種可能:a條件如果不成立的話,就會直接跳出整個嵌套結構,不會去管b,c,d條件是否成立。如果這樣做的話,層層包裹的if結構會使代碼嵌套過深,難以編輯。
為了解決上面的問題,一般來說會采用排除法,即對每一個條件進行排除,條件全部成立在執行特定的操作。
var t = true;
if (!a) {
t = false;
}
if (!b) {
t = false;
}
if (!c) {
t = false;
}
if (!d) {
t = false;
}
if (t) {
// 條件全部符合要求
}
排除法有效的避免了上面所說的條件結構的多重嵌套問題,且更加符合人的思維模式。當然,也存在一些局限性,一旦發生錯誤的話,就要放棄後面的操作。如果想要防止這類問題發生,可以在設計一個標示變量來跟蹤整個操作行為。
容易在 if 裡犯的小錯誤
不知道大家有木有犯過下面這種錯誤:
// 第一種
if (i = 1) {
alert(i);
}
// 第二種
if (i = 1) ;
{
alert(i);
}
第一種情況是,有時候會把比較運算=== or ==符錯寫為賦值運算符=。而且這種錯誤一般很難發現,由於它是一個合法的表達式,不會導致編譯錯誤。
最後就把常量放在左邊,把變量放在右邊,這樣寫的話,就算你把=當作了===來使用也會報錯。
if (1 === i) {
alert(i);
}
第二種是,在if的括號後面加了個分號,導致整個結構的邏輯就發生了變化。我們應該牢記條件表達式之後不允許添加分化,最後就通過把大括號與條件表達式寫在一行來防止犯錯。
if (i) {
alert(i);
}
編寫 switch 要注意的地方
千萬不要忘記在每一個case語句後面放一個break語句。也可以放一個return或者throw。
防止 switch 貫穿
在switch語句中,除非明確地中斷流程,否則每次條件判斷後就會貫穿到下一個case條件。在執行switch語句中,js會先計算switch條件的值,然後使用這個值與每個case中的值進行比較,如果相同則執行標簽下的語句。在執行的時候如果遇到跳轉語句,就會跳出switch結構,否則就會按照順序執行下去,知道switch語句末尾。如果沒有匹配的case的話就會執行default的語句。
switch (a = 3) {
case 3 - 2:
alert(1);
break;
case 1 + 1:
alert(2);
break;
}
上面的switch語句中,case語句只是指明了想要執行代碼的起點,並沒有指明終點,如果沒有在case從句中添加break語句,則會發生連續貫穿現象,從而忽略後面的case從句,這樣就會造成switch結構的邏輯混亂。