switch語句的妙用(必看篇)
switch語句的普通用法很簡單,如下:
var a = 3;
switch (a) {
case 1:
console.log(a);
break;
case 2:
case 3:
console.log(a);
break;
default:
break;
}
這里a和case列表中從上而下逐一做比較,如果匹配就執(zhí)行case中的代碼,若有break則跳出,無break則繼續(xù)往下匹配,直到新的匹配和break或switch代碼塊結束。
注意:
a和case值的匹配算法是執(zhí)行嚴格相等比較的(‘==='),通常a和case的值都是簡單值。
case的值除了簡單值之外,還可以是各種表達式,switch (a){...}中的a會和case中的表達式的結果值進行比較(“===”),由此,我們可以這樣:
var a = [4], b = '3';
function foo(a, b) {
return Math.abs(a - b) < 2;
}
switch (true) {
case !(a && b): //過濾掉a,b其中有為‘假值'的情況
console.log('a:'+a,' b:'+b);
break;
case foo(a,b): //當a,b的差值在2以內(nèi),foo函數(shù)返回true
console.log('a - b < '+Math.abs(a-b));
case a == b:
console.log(a+'=='+b);
break;
case a < b:
console.log(a+'<'+b);
break;
case a > b:
console.log(a+'>'+b);
break;
default:
break;
}
以上例子中,true和每個case的表達式的值進行嚴格相等比較,當且僅當case表達式的值為布爾值true時才匹配,任何其他真值都不匹配。
注意:case !(a && b): 必須把&&、||運算符的結果進行顯示轉(zhuǎn)換為布爾值,才能匹配(因為&&、||的表達式的返回值不是布爾類型,它返回的是表達式中第一個為true、或第一個為false的那個值)
所以,只要你想得到的,只要符合規(guī)則,都能用switch實現(xiàn)!就是不知道這樣寫的代碼好不好了!
以上就是小編為大家?guī)淼膕witch語句的妙用(必看篇)全部內(nèi)容了,希望大家多多支持腳本之家~
相關文章
JS中實現(xiàn)函數(shù)return多個返回值的實例
下面小編就為大家?guī)硪黄狫S中實現(xiàn)函數(shù)return多個返回值的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
javascript創(chuàng)建createXmlHttpRequest對象示例代碼
這篇文章主要介紹了javascript創(chuàng)建createXmlHttpRequest對象的示例代碼。需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
javascript設置連續(xù)兩次點擊按鈕時間間隔的方法
這篇文章主要介紹了javascript設置連續(xù)兩次點擊按鈕時間間隔的方法,是非常實用的技巧,需要的朋友可以參考下2014-10-10
fckeditor部署到weblogic出現(xiàn)xml無法讀取及樣式不能顯示問題的解決方法
這篇文章主要介紹了fckeditor部署到weblogic出現(xiàn)xml無法讀取及樣式不能顯示問題的解決方法,分析了問題出現(xiàn)的原因及相關配置文件設置技巧,需要的朋友可以參考下2017-03-03
多選列表框動態(tài)添加,移動,刪除,全選等操作的簡單實例
本篇文章主要是對多選列表框動態(tài)添加,移動,刪除,全選等操作的簡單實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01

