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代碼塊結(jié)束。
注意:
a和case值的匹配算法是執(zhí)行嚴(yán)格相等比較的(‘==='),通常a和case的值都是簡單值。
case的值除了簡單值之外,還可以是各種表達(dá)式,switch (a){...}中的a會和case中的表達(dá)式的結(jié)果值進(jìn)行比較(“===”),由此,我們可以這樣:
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): //當(dāng)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的表達(dá)式的值進(jìn)行嚴(yán)格相等比較,當(dāng)且僅當(dāng)case表達(dá)式的值為布爾值true時才匹配,任何其他真值都不匹配。
注意:case !(a && b): 必須把&&、||運(yùn)算符的結(jié)果進(jìn)行顯示轉(zhuǎn)換為布爾值,才能匹配(因為&&、||的表達(dá)式的返回值不是布爾類型,它返回的是表達(dá)式中第一個為true、或第一個為false的那個值)
所以,只要你想得到的,只要符合規(guī)則,都能用switch實現(xiàn)!就是不知道這樣寫的代碼好不好了!
以上就是小編為大家?guī)淼膕witch語句的妙用(必看篇)全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
js字符串轉(zhuǎn)json對象的四種實現(xiàn)方法
使用ajax的開發(fā)項目過程中,經(jīng)常需要將json格式的字符串返回到前端,前端解析成js對象(JSON),下面這篇文章主要給大家介紹了關(guān)于js字符串轉(zhuǎn)json對象的四種實現(xiàn)方法,需要的朋友可以參考下2023-04-04layui-table表復(fù)選框勾選的所有行數(shù)據(jù)獲取的例子
今天小編就為大家分享一篇layui-table表復(fù)選框勾選的所有行數(shù)據(jù)獲取的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript 實現(xiàn)打印,打印預(yù)覽,打印設(shè)置
這篇文章主要介紹了JavaScript 實現(xiàn)打印,打印預(yù)覽,打印設(shè)置的方法及示例分享,需要的朋友可以參考下2014-12-12Bootstrap框架結(jié)合jQuery仿百度換膚功能實例解析
這篇文章主要為大家詳細(xì)介紹了Bootstrap框架結(jié)合jQuery仿百度換膚功能實現(xiàn)代碼解析,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09BootStrap的alert提示框的關(guān)閉后再顯示怎么解決
這篇文章主要介紹了BootStrap的alert提示框的關(guān)閉后再顯示問題的相關(guān)資料,需要的朋友可以參考下2016-05-05