十一、JavaScript之——條件判斷語(yǔ)句胶果,循環(huán)

多重條件判斷語(yǔ)句

if語(yǔ)句

語(yǔ)法:

if(條件表達(dá)式){
                語(yǔ)句...
}else if(條件表達(dá)式){
                語(yǔ)句...
}else if(條件表達(dá)式){
                語(yǔ)句...
}else{
                語(yǔ)句...
            }

if...else if...else
當(dāng)該語(yǔ)句執(zhí)行時(shí)匾嘱,會(huì)從上到下依次對(duì)條件表達(dá)式進(jìn)行求值判斷
如果值為true,則執(zhí)行當(dāng)前語(yǔ)句早抠。
如果值為false霎烙,則繼續(xù)向下判斷。
如果所有的條件都不滿足蕊连,則執(zhí)行最后一個(gè)else后的語(yǔ)句
該語(yǔ)句中悬垃,只會(huì)有一個(gè)代碼塊被執(zhí)行,一旦代碼塊執(zhí)行了甘苍,則直接結(jié)束語(yǔ)句

    var today = 4;
 if(today == 1){
    alert('語(yǔ)文');
 }else if(today == 2){
    alert('數(shù)學(xué)');
 }else if(today == 3){
    alert('英語(yǔ)');
 }else if(today == 4){
    alert('美術(shù)');
 }else if(today == 5){
    alert('舞蹈');
 }else{
    alert('不補(bǔ)習(xí)');
 }

條件分支語(yǔ)句也叫switch語(yǔ)句

    語(yǔ)法:
        switch(條件表達(dá)式){
            case 表達(dá)式:
                語(yǔ)句...
                break;
            case 表達(dá)式:
                語(yǔ)句...
                break;
            default:
                語(yǔ)句...
                break;
        }

執(zhí)行流程:
switch...case..語(yǔ)句
在執(zhí)行時(shí)會(huì)依次將case后的表達(dá)式的值和switch后的條件表達(dá)式的值進(jìn)行全等比較尝蠕,
如果比較結(jié)果為true,則從當(dāng)前case處開(kāi)始執(zhí)行代碼载庭。
當(dāng)前case后的所有的代碼都會(huì)執(zhí)行看彼,我們可以在case的后邊跟著一個(gè)break關(guān)鍵字,
這樣可以確保只會(huì)執(zhí)行當(dāng)前case后的語(yǔ)句昧捷,而不會(huì)執(zhí)行其他的case
如果比較結(jié)果為false闲昭,則繼續(xù)向下比較
如果所有的比較結(jié)果都為false,則只執(zhí)行default后的語(yǔ)句

switch語(yǔ)句和if語(yǔ)句的功能實(shí)際上有重復(fù)的靡挥,使用switch可以實(shí)現(xiàn)if的功能序矩,同樣使用if也可以實(shí)現(xiàn)switch的功能,所以我們使用時(shí)跋破,可以根據(jù)自己的習(xí)慣選擇簸淀。

    var today = 4;
    switch(today){
    case 1:
        alert('語(yǔ)文');
        break;//結(jié)束整個(gè)switch語(yǔ)句
    case 2:
        alert('數(shù)學(xué)');
        break;
    case 3:
        alert('英語(yǔ)');
        break;
    case 4:
        alert('美術(shù)');
        break;
    case 5:
        alert('舞蹈');
        break;
    default:
        alert('不補(bǔ)習(xí)');
        break;//最后一個(gè)default可以不寫break,但建議寫上
}

通過(guò)標(biāo)簽獲取元素

獲取頁(yè)面上所有的li
var aLi = document.getElementsByTagName('li');
獲取id為list01的ul

var oList = document.getElementById('list01');
再獲取這個(gè)ul下的所有l(wèi)i

var aLi = oList.getElementsByTagName('li');
      alert(aLi.length);//8
指定索引處的li設(shè)定背景顏色

      aLi[0].style.backgroundColor = 'gold';
      aLi[1].style.backgroundColor = 'gold';
  }
</script>
</head>
<body>
  <ul id="list01">
  <li>1</li>
  <li>2</li>
  <li>3</li>
  <li>4</li>
  <li>5</li>
  <li>6</li>
  <li>7</li>
  <li>8</li>
 </ul>

循環(huán)語(yǔ)句

循環(huán)語(yǔ)句:
通過(guò)循環(huán)語(yǔ)句可以反復(fù)的執(zhí)行一段代碼多次

while循環(huán)
    - 語(yǔ)法:
        while(條件表達(dá)式){
            語(yǔ)句...
        }

    - while語(yǔ)句在執(zhí)行時(shí)毒返,
        先對(duì)條件表達(dá)式進(jìn)行求值判斷租幕,
            如果值為true,則執(zhí)行循環(huán)體拧簸,
                循環(huán)體執(zhí)行完畢以后劲绪,繼續(xù)對(duì)表達(dá)式進(jìn)行判斷
                如果為true,則繼續(xù)執(zhí)行循環(huán)體盆赤,以此類推
            如果值為false贾富,則終止循環(huán)

do...while循環(huán)
    - 語(yǔ)法:
        do{
            語(yǔ)句...
        }while(條件表達(dá)式)

    - 執(zhí)行流程:
        do...while語(yǔ)句在執(zhí)行時(shí),會(huì)先執(zhí)行循環(huán)體牺六,
            循環(huán)體執(zhí)行完畢以后颤枪,在對(duì)while后的條件表達(dá)式進(jìn)行判斷,
            如果結(jié)果為true淑际,則繼續(xù)執(zhí)行循環(huán)體畏纲,執(zhí)行完畢繼續(xù)判斷以此類推
            如果結(jié)果為false扇住,則終止循環(huán)

        實(shí)際上這兩個(gè)語(yǔ)句功能類似,不同的是while是先判斷后執(zhí)行盗胀,
            而do...while會(huì)先執(zhí)行后判斷艘蹋,
        do...while可以保證循環(huán)體至少執(zhí)行一次,
            而while不能

for語(yǔ)句票灰,也是一個(gè)循環(huán)語(yǔ)句簿训,也稱為for循環(huán)
    在for循環(huán)中,為我們提供了專門的位置用來(lái)放三個(gè)表達(dá)式:
        1.初始化表達(dá)式
        2.條件表達(dá)式
        3.更新表達(dá)式

for循環(huán)的語(yǔ)法:
        for(①初始化表達(dá)式;②條件表達(dá)式;④更新表達(dá)式){
            ③語(yǔ)句...
        }

        for循環(huán)的執(zhí)行流程:
            ①執(zhí)行初始化表達(dá)式米间,初始化變量(初始化表達(dá)式只會(huì)執(zhí)行一次)
            ②執(zhí)行條件表達(dá)式,判斷是否執(zhí)行循環(huán)膘侮。
                如果為true屈糊,則執(zhí)行循環(huán)③
                如果為false,終止循環(huán)
            ④執(zhí)行更新表達(dá)式琼了,更新表達(dá)式執(zhí)行完畢繼續(xù)重復(fù)②

任意一種循環(huán)都可以互相嵌套

創(chuàng)建一個(gè)循環(huán)逻锐,往往需要三個(gè)步驟
1.創(chuàng)初始化一個(gè)變量
var j = 0;
2.在循環(huán)中設(shè)置一個(gè)條件表達(dá)式
while(j < aLi.length){
aLi[j].style.background = 'gold';
3.定義一個(gè)更新表達(dá)式,每次更新初始化變量
j++;
以下是死循環(huán)的寫法
像這種將條件表達(dá)式寫死為true的循環(huán)雕薪,叫做死循環(huán)
該循環(huán)不會(huì)停止昧诱,除非瀏覽器關(guān)閉,死循環(huán)在開(kāi)發(fā)中慎用
可以使用break所袁,來(lái)終止循環(huán)

  while(true){
      if(j>10){
          break;//退出整個(gè)循環(huán)
      }
      j++;
  }
  //for循環(huán)的死循環(huán)寫法
  for(;;){

break關(guān)鍵字可以用來(lái)退出switch或循環(huán)語(yǔ)句
不能在if語(yǔ)句中使用break和continue
break關(guān)鍵字盏档,會(huì)立即終止離他最近的那個(gè)循環(huán)語(yǔ)句
continue關(guān)鍵字可以用來(lái)跳過(guò)當(dāng)次循環(huán)
同樣continue也是默認(rèn)只會(huì)對(duì)離他最近的循環(huán)循環(huán)起作用

可以為循環(huán)語(yǔ)句創(chuàng)建一個(gè)label,來(lái)標(biāo)識(shí)當(dāng)前的循環(huán)
label:循環(huán)語(yǔ)句
使用break語(yǔ)句時(shí)燥爷,可以在break后跟著一個(gè)label蜈亩,
這樣break將會(huì)結(jié)束指定的循環(huán),而不是最近的

  outer:
  for(var i=0 ; i<5 ; i++){
      console.log("@外層循環(huán)"+i);
      for(var j=0 ; j<5; j++){
          console.log("內(nèi)層循環(huán):"+j);
          break outer;
      }
  }

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末前翎,一起剝皮案震驚了整個(gè)濱河市稚配,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌港华,老刑警劉巖道川,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異立宜,居然都是意外死亡冒萄,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門赘理,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)宦言,“玉大人,你說(shuō)我怎么就攤上這事商模〉焱” “怎么了蜘澜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)响疚。 經(jīng)常有香客問(wèn)我鄙信,道長(zhǎng),這世上最難降的妖魔是什么忿晕? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任装诡,我火速辦了婚禮,結(jié)果婚禮上践盼,老公的妹妹穿的比我還像新娘鸦采。我一直安慰自己,他們只是感情好咕幻,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布渔伯。 她就那樣靜靜地躺著,像睡著了一般肄程。 火紅的嫁衣襯著肌膚如雪锣吼。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,598評(píng)論 1 305
  • 那天蓝厌,我揣著相機(jī)與錄音玄叠,去河邊找鬼。 笑死拓提,一個(gè)胖子當(dāng)著我的面吹牛读恃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播崎苗,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼狐粱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了胆数?” 一聲冷哼從身側(cè)響起肌蜻,我...
    開(kāi)封第一講書(shū)人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎必尼,沒(méi)想到半個(gè)月后蒋搜,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡判莉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年豆挽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片券盅。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡帮哈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出锰镀,到底是詐尸還是另有隱情娘侍,我是刑警寧澤咖刃,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站憾筏,受9級(jí)特大地震影響嚎杨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜氧腰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一枫浙、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧古拴,春花似錦箩帚、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至满力,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間轻纪,已是汗流浹背油额。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留刻帚,地道東北人潦嘶。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像崇众,于是被迫代替她去往敵國(guó)和親掂僵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

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

  • 第2章 基本語(yǔ)法 2.1 概述 基本句法和變量 語(yǔ)句 JavaScript程序的執(zhí)行單位為行(line)顷歌,也就是一...
    悟名先生閱讀 4,149評(píng)論 0 13
  • 多重條件判斷語(yǔ)句 if語(yǔ)句 語(yǔ)法: if...else if...else當(dāng)該語(yǔ)句執(zhí)行時(shí)舱卡,會(huì)從上到下依次對(duì)條件表達(dá)...
    咻咻咻滴趙大妞閱讀 966評(píng)論 0 1
  • 1. 條件分支語(yǔ)句 2. 數(shù)組 3. 獲取標(biāo)簽過(guò)去元素 4. 循環(huán)語(yǔ)句4.1 for 循環(huán)4.2 while循環(huán)4...
    zmm0404閱讀 838評(píng)論 0 0
  • 去年10月本來(lái)是作為志愿者去昆明參加"有靈且美"在昆明女中的藝術(shù)營(yíng)。我提前了大概十天的時(shí)間去到了昆明队萤,然后一到昆明...
    姜敏悅閱讀 230評(píng)論 0 0
  • 1.沒(méi)有列日計(jì)劃的一天轮锥,一團(tuán)糟。重要的事沒(méi)完成要尔,不重要的事做了兩三個(gè)小時(shí)[微笑] 2.從今天起舍杜, 每天要求自己學(xué)3...
    冰糖閱讀 94評(píng)論 0 0