JavaScript條件語句

在JavaScript 中提供if結(jié)構(gòu)和switch結(jié)構(gòu)馋艺,滿足條件判斷,才會執(zhí)行相應(yīng)的語句嘉栓。

1. if語句

if語句的幾種形式

  • 第一種形式

    if (條件表達(dá)式) {
        條件滿足執(zhí)行的語句
    }
    
  • 第二種形式

    if (條件表達(dá)式) {
        滿足條件表達(dá)式執(zhí)行的語句
    } else {
        不滿足條件執(zhí)行的語句
    }
    
  • 第三種形式

    if (條件表達(dá)式1) {
        滿足條件表達(dá)式1執(zhí)行的語句
    } else if (條件表達(dá)式2) {
        滿足條件表達(dá)式2執(zhí)行的語句
    }
    ...
    else{
        都不滿足條件執(zhí)行的語句
    }
    

2. if語句的幾個(gè)注意點(diǎn)

  • 不是非布爾類型的先會轉(zhuǎn)換成布爾類型
// Boolean(null) ==> false
if(null){
    console.log('語句A');
}else{
    console.log('語句B'); 
}
// Boolean('123') ==> true
if ('123') {
    console.log('語句A');
} else {
    console.log('語句B');
}
  • 對于 ==宏榕、===判斷, 將常量寫在前面
var num = 10;
// 這里價(jià)格常量寫在前面 是為了防止寫錯(cuò)
// if (num = 5) 
if(5 == num){
    console.log("語句A");
}
console.log("語句B");
  • if/else后面的大括號都可以省略, 但是省略之后只有緊隨其后的語句受到控制
if (false)
    console.log("語句A");
    console.log("語句B"); 
// 會輸出語句B  因?yàn)橹挥芯o隨其后的語句才有用

3. switch語句

switch格式

switch(表達(dá)式){
    case 表達(dá)式A:
        語句A;
        break;
    case 表達(dá)式B:
        語句B;
        break;
        ... ...
        default:
        前面所有case都不匹配執(zhí)行的代碼;
        break;
}

switch特點(diǎn)

會從上至下的依次判斷每一個(gè)case是否和()中表達(dá)式的結(jié)果相等, 如果相等就執(zhí)行對應(yīng)case后面的代碼, 如果前面所有的case都不匹配, 那么就會執(zhí)行default后面的代碼

并且所有的case和default只有一個(gè)會被執(zhí)行, 并且只會被執(zhí)行一次

var day = 7;
switch (day) {
    case 1:
        console.log("周一");
        break;
    case 2:
        console.log("周二");
        break;
    case 3:
        console.log("周三");
        break;
    case 4:
        console.log("周四");
        break;
    case 5:
        console.log("周五");
        break;
    case 6:
        console.log("周六");
        break;
    case 7:
        console.log("周日");
        break;
    default:
        console.log("你是外星人吧拓诸!");
        break;
}

4. switch的幾個(gè)注意點(diǎn)

  • case判斷的是===, 而不是==
var age = 18;
switch (age) {
    case "18":
        console.log("字符串的18");
        break;
    default:
        console.log("不匹配字符串的18!"); // 打印不匹配字符串的18麻昼!
        break;
}
  • switch()中可以是常量也可以是變量還可以是表達(dá)式
var total = 18;
switch (16 + 2 ) {
    case 18:
        console.log("總共18");
        break;
    default:
        console.log("什么也不是奠支!");
        break;
}
  • case后面可以是常量也可以是變量還可以是表達(dá)式
var total = 18;
switch (18) {
        // 表達(dá)式
        // case 16 + 2:
        // 常量
        // case 18:
        // 變量
    case total:
        console.log("總共18");
        break;
    default:
        console.log("什么也不是!");
        break;
}
  • break的作用是立即結(jié)束整個(gè)switch語句
var num = 1;
switch (num) {
    case 1:
        console.log("1");
        break;
    case 2:
        console.log("2");
        break;
    default:
        console.log("Other");
        break;
}
  • default不一定要寫在最后抚芦,default無論放到什么位置, 都會等到所有case都不匹配再執(zhí)行
var num = 7;
switch (num) {
        // default:
        //     console.log("Other");
        //     break;
    case 1:
        console.log("1");
        break;
    default:
        console.log("Other");
        break;
    case 2:
        console.log("2");
        break;
}
  • 和if/else中的else一樣, default也可以省略
var num = 7;
switch (num) {
    case 1:
        console.log("1");
        break;
    case 2:
        console.log("2");
        break;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末倍谜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子叉抡,更是在濱河造成了極大的恐慌尔崔,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件褥民,死亡現(xiàn)場離奇詭異季春,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)消返,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進(jìn)店門载弄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人撵颊,你說我怎么就攤上這事宇攻。” “怎么了倡勇?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵逞刷,是天一觀的道長。 經(jīng)常有香客問我妻熊,道長夸浅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任固耘,我火速辦了婚禮题篷,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘厅目。我一直安慰自己番枚,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布损敷。 她就那樣靜靜地躺著葫笼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪拗馒。 梳的紋絲不亂的頭發(fā)上路星,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機(jī)與錄音诱桂,去河邊找鬼洋丐。 笑死呈昔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的友绝。 我是一名探鬼主播堤尾,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼迁客!你這毒婦竟也來了郭宝?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤粘室,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后卜范,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體衔统,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年先朦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缰冤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片犬缨。...
    茶點(diǎn)故事閱讀 38,569評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡喳魏,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出怀薛,到底是詐尸還是另有隱情刺彩,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布枝恋,位于F島的核電站创倔,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏焚碌。R本人自食惡果不足惜畦攘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望十电。 院中可真熱鬧知押,春花似錦、人聲如沸鹃骂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽畏线。三九已至静盅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寝殴,已是汗流浹背蒿叠。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工明垢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人市咽。 一個(gè)月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓袖外,卻偏偏與公主長得像,于是被迫代替她去往敵國和親魂务。 傳聞我的和親對象是個(gè)殘疾皇子曼验,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內(nèi)容