一文熟練掌握J(rèn)avaScript的switch用法
前言
JavaScript switch 語(yǔ)句是一種根據(jù)不同條件在代碼中做出決策的方法。它比使用 if-else 語(yǔ)句更有條理、更簡(jiǎn)潔。switch 語(yǔ)句通過(guò)計(jì)算給定的表達(dá)式(可以是變量或值),并將其與幾種可能的情況進(jìn)行比較。如果表達(dá)式的值與其中一種情況匹配,則執(zhí)行關(guān)聯(lián)的代碼塊(一組指令)。如果未找到匹配項(xiàng),則可以執(zhí)行可選的默認(rèn)情況作為后備,這意味著它會(huì)在其他情況都不適用時(shí)運(yùn)行。
我們來(lái)看一個(gè)簡(jiǎn)單的例子:
switch (day) {
case "Monday":
console.log("工作日開(kāi)始");
break;
case "Friday":
console.log("工作日結(jié)束");
break;
default:
console.log("常規(guī)日期");
}
通過(guò)掌握 switch 語(yǔ)句,我們可以編寫(xiě)更干凈、更高效、組織更好的 JavaScript 代碼,最終提高我們的整體編程技能。
switch 基礎(chǔ)介紹
switch 語(yǔ)句以關(guān)鍵字 switch 開(kāi)頭,后跟括號(hào)中的表達(dá)式。該表達(dá)式與包含在 switch 塊中的一系列 case 標(biāo)簽進(jìn)行比較。每個(gè) case 標(biāo)簽代表一個(gè)不同的值,當(dāng)表達(dá)式與 case 標(biāo)簽的值匹配時(shí),執(zhí)行 case 后面的代碼塊。語(yǔ)句break通常用于在執(zhí)行匹配的 case 后退出 switch 塊,確保僅運(yùn)行預(yù)期的代碼塊,并防止跳到下一個(gè) case。同時(shí)還可以包含默認(rèn)情況,以便在沒(méi)有任何情況標(biāo)簽與表達(dá)式匹配時(shí)提供后備操作,從而確保對(duì)未知值的響應(yīng)。
使用語(yǔ)法:
switch(expression) {
case {value1}:
// 要執(zhí)行的代碼
break
case {value2}:
// 要執(zhí)行的代碼
break
default:
// 默認(rèn)情況
}
case
判斷條件,case的條件相當(dāng)于===,即全等條件下才成立。
default
當(dāng)沒(méi)有其他情況與提供的表達(dá)式匹配時(shí),將執(zhí)行 switch 語(yǔ)句中的默認(rèn)情況。它可以作為處理意外或未知值的后備措施,確保即使沒(méi)有匹配的情況也能提供響應(yīng)。
break
break關(guān)鍵字用在 switch 語(yǔ)句中,一旦找到并執(zhí)行匹配的 case 就退出 switch 塊。它阻止代碼繼續(xù)執(zhí)行剩余的情況,確保只生成正確的輸出。
一個(gè) case 在 switch 語(yǔ)句中不能有多個(gè)條件。要在一種情況下合并多個(gè)條件,可以在case中省略break,從而允許代碼執(zhí)行繼續(xù)到下一個(gè) case,直到遇到下一個(gè)break或到達(dá) switch 塊的末尾。當(dāng)多個(gè)條件共享相同的輸出或操作時(shí),這可能很有用。
switch (day) {
case "Monday":
case "Tuesday":
case "Wednesday":
case "Thursday":
case "Friday":
console.log("工作日");
break;
default:
console.log("周末");
}
switch 與 if-else
當(dāng)需要處理多個(gè)條件時(shí),switch 語(yǔ)句是使用 if-else 語(yǔ)句的替代方法。雖然 if-else 語(yǔ)句適合檢查一系列可以表示為 true 或 false 的條件,但 switch 語(yǔ)句在處理可以采用多個(gè)不同值的單個(gè)表達(dá)式時(shí)更有效。從本質(zhì)上講,當(dāng)我們有多個(gè)相關(guān)條件需要管理時(shí),switch 語(yǔ)句可以使我們的代碼更干凈、更有組織性并且更易于閱讀。
例如,以下是一個(gè) if-else 結(jié)構(gòu)的例子:
if (color === "red") {
console.log("The color is red");
} else if (color === "blue") {
console.log("The color is blue");
} else if (color === "green") {
console.log("The color is green");
} else {
console.log("Unknown color");
}
使用switch語(yǔ)法:
switch (color) {
case "red":
console.log("The color is red");
break;
case "blue":
console.log("The color is blue");
break;
case "green":
console.log("The color is green");
break;
default:
console.log("Unknown color");
}
在處理大量條件的情況下,switch 語(yǔ)句提供了一種更有組織性和可讀性的方式來(lái)處理多個(gè)條件。在 switch 語(yǔ)句中,括號(hào)內(nèi)的變量或值(在本例中為變量color)是需要計(jì)算的表達(dá)式。
什么時(shí)候使用switch
- 大量單變量條件:當(dāng)需要處理大量條件時(shí),
switch語(yǔ)句通常比if-else鏈更有組織性且更易于閱讀。 - 單變量評(píng)估:如果我們的條件是基于具有多個(gè)不同值的單個(gè)變量或表達(dá)式,則
switch語(yǔ)句可以提供比if-else模式更高效、更清晰的結(jié)構(gòu)。 - 更快的代碼執(zhí)行速度:在某些情況下,
JavaScript引擎可以?xún)?yōu)化switch語(yǔ)句,與一系列if-else語(yǔ)句相比,可以實(shí)現(xiàn)更快的代碼執(zhí)行速度。 - 更容易維護(hù):
switch語(yǔ)句可以使添加、刪除或修改條件變得更加容易,因?yàn)槊總€(gè)條件在switch塊中都是獨(dú)立的。相反,當(dāng)需要更改時(shí),if-else鏈可能需要更廣泛的修改。 - 默認(rèn)回退:
switch語(yǔ)句提供可選的默認(rèn)情況,當(dāng)其他情況都不與給定表達(dá)式匹配時(shí)可以執(zhí)行該默認(rèn)情況。此功能允許以一種干凈的方式處理意外或未知值。
什么時(shí)候使用if-else
- 復(fù)雜條件:如果我們的條件涉及復(fù)雜邏輯、多個(gè)變量或關(guān)系和邏輯運(yùn)算符,則
if-else模式提供了更大的靈活性,并且比switch語(yǔ)句更適合這些情況。 - 基于范圍的條件:當(dāng)我們需要檢查一系列非離散值或條件時(shí),
if-else模式提供了更好的解決方案,因?yàn)?nbsp;switch語(yǔ)句是為比較離散值而設(shè)計(jì)的。 - 條件數(shù)量少:如果只有幾個(gè)簡(jiǎn)單的條件需要檢查,則使用
if-else模式比switch語(yǔ)句更直接、更容易編寫(xiě)。 - 非常量:
switch語(yǔ)句需要case標(biāo)簽為常量值,這意味著它們不能是在運(yùn)行時(shí)更改的表達(dá)式。如果我們需要判斷非常量值的條件,則if-else模式是合適的選擇。 - 判斷
true或false值:當(dāng)我們需要檢查值是真值還是假值時(shí),If-else模式適用。switch語(yǔ)句不是為這種類(lèi)型的評(píng)估而設(shè)計(jì)的,并且需要更詳細(xì)的代碼才能完成相同的結(jié)果。 - 提前退出條件:如果我們有提前退出條件,一旦滿(mǎn)足特定條件就不需要進(jìn)一步判斷,則
if-else模式可能會(huì)更有效。使用switch語(yǔ)句,即使發(fā)現(xiàn)早期匹配,也會(huì)判斷所有情況(除非我們使用了break語(yǔ)句)。
常見(jiàn)問(wèn)題
多個(gè)case執(zhí)行(忘記使用該break語(yǔ)句)
使用 switch 語(yǔ)句時(shí)的一個(gè)常見(jiàn)錯(cuò)誤是在每個(gè) case 后面都沒(méi)有包含break語(yǔ)句。此錯(cuò)誤會(huì)導(dǎo)致執(zhí)行所有的case.
不正確的比較值和類(lèi)型
switch 語(yǔ)句使用嚴(yán)格比較,這在比較不同數(shù)據(jù)類(lèi)型時(shí)可能會(huì)導(dǎo)致意外結(jié)果。在下面的示例中,字符串"2"不等于數(shù)字2。
const num = '2';
switch (num) {
case 2:
console.log(2);
break;
default:
console.log('不是數(shù)字2');
}
// 輸出 不是數(shù)字2
范圍界定問(wèn)題
switch 語(yǔ)句中的一個(gè)常見(jiàn)錯(cuò)誤是聲明了沒(méi)有塊作用域或不正確作用域的變量,導(dǎo)致它們?cè)谄渌闆r下可以訪問(wèn),或者產(chǎn)生語(yǔ)法錯(cuò)誤。
總結(jié)
到此這篇關(guān)于JavaScript的switch用法的文章就介紹到這了,更多相關(guān)js的switch用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
JavaScript實(shí)現(xiàn)數(shù)值自動(dòng)增加動(dòng)畫(huà)
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)數(shù)值自動(dòng)增加動(dòng)畫(huà),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法
本文主要介紹了JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
JavaScript利用normalizr實(shí)現(xiàn)復(fù)雜數(shù)據(jù)轉(zhuǎn)換
當(dāng)我們需要進(jìn)行數(shù)據(jù)轉(zhuǎn)換以便拆分和維護(hù)時(shí),可以使用redux作者 Dan Abramov 編寫(xiě)的normalizr來(lái)處理數(shù)據(jù),本文將為大家詳細(xì)講講其用法,感興趣的可以了解一下2022-07-07
javascript實(shí)現(xiàn)根據(jù)函數(shù)名稱(chēng)字符串動(dòng)態(tài)執(zhí)行函數(shù)的方法示例
這篇文章主要介紹了javascript實(shí)現(xiàn)根據(jù)函數(shù)名稱(chēng)字符串動(dòng)態(tài)執(zhí)行函數(shù)的方法,結(jié)合實(shí)例形式分析了JS函數(shù)名的判斷及函數(shù)動(dòng)態(tài)調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2016-12-12
js+html實(shí)現(xiàn)網(wǎng)頁(yè)五子棋
這篇文章主要為大家詳細(xì)介紹了js+html實(shí)現(xiàn)網(wǎng)頁(yè)五子棋,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
微信小程序入口場(chǎng)景的問(wèn)題集合與相關(guān)解決方法
這篇文章主要介紹了微信小程序入口場(chǎng)景的問(wèn)題集合與相關(guān)解決方法,從零開(kāi)始開(kāi)發(fā)一個(gè)小程序,大多數(shù)坑點(diǎn)都是在微信小程序的各個(gè)入口場(chǎng)景處。所以這里整理一下微信小程序的各個(gè)入口場(chǎng)景會(huì)面臨的問(wèn)題以及解決方案,需要的朋友可以參考下2019-06-06
用JS中split方法實(shí)現(xiàn)彩色文字背景效果實(shí)例
這篇文章介紹的是利用Javascript中的split方法來(lái)實(shí)現(xiàn)彩色文字背景效果,實(shí)現(xiàn)后的效果很好,有需要的可以參考借鑒。2016-08-08
javascript使用正則控制input輸入框允許輸入的值方法大全
在做項(xiàng)目的時(shí)候,我們經(jīng)常會(huì)遇到控制input輸入框允許輸入的值為數(shù)字,字母,漢字或者混排的情況,那么我們?cè)趺磥?lái)處理呢,下面我們就來(lái)探討怎么通過(guò)用javascript正則來(lái)實(shí)現(xiàn)2014-06-06

