JS語(yǔ)句

條件語(yǔ)句

if 條件語(yǔ)句

語(yǔ)法: if ( condition ) statement1 else statement2
語(yǔ)法: if ( 條件 ) { 語(yǔ)句1 } else { 語(yǔ)句2 }

其中condition(條件)可以是任意表達(dá)式,求值結(jié)果不一定是布爾值,ECMAScript會(huì)自動(dòng)調(diào)用Boolean()轉(zhuǎn)換函數(shù)將結(jié)果轉(zhuǎn)換為一個(gè)布爾值,如果結(jié)果是true,執(zhí)行statement1;如果是false,執(zhí)行statemen2,兩個(gè)語(yǔ)句可以是代碼,也可以代碼塊(以一對(duì)花括號(hào)括起來(lái)的多行代碼),

demo1 :
if( i > 25 )
  alert ( " Greater than 25 . ");        //單行語(yǔ)句
else {
  alert ( " Less than  or equal to 25 .");        //代碼塊中的語(yǔ)句
}

demo2 :
var isMale = false;
  if(isMale){
    document.write('男');
  } else {
    document.write('女');  //上面是false,打印為女
  }

不過(guò)if語(yǔ)句也可以擴(kuò)展為嵌套if

if(condition) statement1 else if (condition2) statement2 else statement3
if( 條件 ) { 語(yǔ)句1 } else if (條件2) { 語(yǔ)句2 } else { 語(yǔ)句3 }

demo:
var score = 85;
  if(score > 80){
    document.write('A');
  } else if(score > 60){
    document.write('B');
  } else {
    document.write('C');
  }

switch語(yǔ)句

switch語(yǔ)句if語(yǔ)句關(guān)系密切

語(yǔ)法:switch (expression) {  //表達(dá)式
           case value : statement  //值1:語(yǔ)句
               break;  //跳出
           case value : statement
               break;
           case value : statement
               break;
           case value : statement
               break;
           default : statement
       }

demo:
var degree = 'A';
  switch(degree){
    case 'A':
      document.write('優(yōu)秀');
      break;
    case 'B':
      document.write('良好');
      break;
    default:
      document.write('合格');
  }

switch語(yǔ)句中每一個(gè)情形(case)的含義:"如果表達(dá)式等于這個(gè)值(value),則執(zhí)行后面的語(yǔ)句(statement)".而break關(guān)鍵字會(huì)導(dǎo)致代碼執(zhí)行流跳出switch語(yǔ)句.如果省略break,會(huì)導(dǎo)致執(zhí)行完當(dāng)前case,繼續(xù)執(zhí)行下一個(gè)case.default關(guān)鍵字用于在表達(dá)式不匹配前面任何一種情況時(shí)候,執(zhí)行機(jī)動(dòng)代碼.


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

do-while 循環(huán)語(yǔ)句

do-while 語(yǔ)句是一種后測(cè)試循環(huán)語(yǔ)句,即在對(duì)表達(dá)式求值之前,循環(huán)體內(nèi)的代碼至少會(huì)被執(zhí)行一次.

語(yǔ)法:  do {
          statement
       } while ( expression )

var i = 11 ;
do {
    document.write(i);
    i++;
} while ( i <= 10 )    //11

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

while語(yǔ)句屬于前測(cè)試循環(huán)語(yǔ)句,在循環(huán)體內(nèi)的代碼被執(zhí)行之前,就會(huì)對(duì)出口條件求值,循環(huán)體內(nèi)的代碼可能永遠(yuǎn)不會(huì)被執(zhí)行.

語(yǔ)法: while ( expression ) statement
      while( 表達(dá)式 ){ 語(yǔ)句 }
示例:
var i = 1 ;
while ( i <= 10 ) {
   document.write(i);
   i++;
}    //12345678910

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

for語(yǔ)句也是一種前測(cè)試循環(huán)語(yǔ)句,但它具有在執(zhí)行循環(huán)之前初始化變量和定義循環(huán)后要執(zhí)行的代碼

語(yǔ)法:for( initialization; expression; post-loop-expression)statement
     for(初始化; 循環(huán)條件; 更新表達(dá)式){語(yǔ)句}    //中文解釋
示例:
var count = 10 ;
  for(var i = 0; i<count; i++){
  alert(i);
}

另外,for語(yǔ)句中的初始化表達(dá)式 控制表達(dá)式 循環(huán)后表達(dá)式都是可選的,這三個(gè)表達(dá)式全部省略,就會(huì)創(chuàng)建一個(gè)無(wú)限循環(huán),

for( ; ;){        //無(wú)限循環(huán)
  dosomething();
}

break和continue語(yǔ)句

break和continue語(yǔ)句用于循環(huán)中準(zhǔn)確控制代碼的執(zhí)行.其中,break語(yǔ)句會(huì)立即退出循環(huán),強(qiáng)制執(zhí)行循環(huán)后面的語(yǔ)句.而continue語(yǔ)句雖然也是立即退出循環(huán),但退出循環(huán)后會(huì)從循環(huán)的頂部繼續(xù)執(zhí)行.

var num = 0 ;
for(var i =0; i<10; i++){
  if(i%5 == 0) {
    break;
  }
  num++;
}
alert(num);    //4

結(jié)果4是次數(shù),break語(yǔ)句的執(zhí)行,導(dǎo)致了循環(huán)在num再次遞增之前就退出了了.(跳出整個(gè)循環(huán)體)

var num = 0 ;
for(var i =0; i<10; i++){
  if(i%5 == 0) {
    continue;
  }
  num++;
}
alert(num);    //8

結(jié)果為8,說(shuō)明執(zhí)行了8次,當(dāng)變量i=5時(shí),循環(huán)會(huì)在num再次遞增之前退出,但接下來(lái)執(zhí)行下一次循環(huán),即i=6的循環(huán),于是,循環(huán)再次執(zhí)行了(跳出一次循環(huán)體)


for - in語(yǔ)句

for-in語(yǔ)句是一種精準(zhǔn)的迭代語(yǔ)句,可以用來(lái)枚舉對(duì)象的屬性.

語(yǔ)法:for(property in expression) statement
     for(屬性名 in 對(duì)象) {語(yǔ)句}     //中文解釋
示例:
var cat = {
  name:'kitty',
  age:2,
  mew : function () {
    console.log("喵喵喵")
   }
}
如果我們想把上面的對(duì)象的屬性名都打印出來(lái),可以用for-in語(yǔ)句:
for(var p in cat){
  document.write(p);
}        //name age mew

如果表示要迭代的對(duì)象的變量值為null和undefined,for-in會(huì)拋出錯(cuò)誤,不過(guò)ECMAScript5更改了這一行為,不在拋出錯(cuò)誤,只是不執(zhí)行循環(huán)體,,所以建議使用for-in之前,確認(rèn)對(duì)象的值是不是null或undefined


with語(yǔ)句

with語(yǔ)句的作用是將代碼的作用域設(shè)置到一個(gè)特定的對(duì)象中.

語(yǔ)法:with(expression) statement
     with(表達(dá)式) {語(yǔ)句}     //中文解釋
with語(yǔ)句

定義with語(yǔ)句的目的是為了簡(jiǎn)化多次編寫同一個(gè)對(duì)象的工作,嚴(yán)格模式下不允許使用with語(yǔ)句

由于大量使用with語(yǔ)句會(huì)導(dǎo)致性能下降,同時(shí)也會(huì)給調(diào)試代碼造成困難,因此開發(fā)大型應(yīng)用程序時(shí),不建議使用with語(yǔ)句


異常捕獲語(yǔ)句

try{
  語(yǔ)句
} catch (exception){
  語(yǔ)句
} finally{
  語(yǔ)句
}
demo:
 try{
    document.write(notDefined);
  }catch(error){
    console.log(error);
    alert(error);
  }finally{
    alert('finally');
  }  //notDefined變量未定義的,是錯(cuò)誤的,會(huì)執(zhí)行catch里面的語(yǔ)句.

如果try里語(yǔ)句執(zhí)行出錯(cuò)的話,會(huì)到catch語(yǔ)句中在語(yǔ)句中可以對(duì)錯(cuò)誤執(zhí)行一些操作,不管try語(yǔ)句是否出錯(cuò),都會(huì)執(zhí)行finally語(yǔ)句.一般用于我們執(zhí)行的代碼不知道它是否出錯(cuò),把它放到try catch語(yǔ)句中


語(yǔ)句的學(xué)習(xí)很簡(jiǎn)單,難得是實(shí)際應(yīng)用,所以多練

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • javascript程序就是一系列可執(zhí)行語(yǔ)句的集合。(ps我看了全位置呢比js高級(jí)講解的更加系統(tǒng)和詳細(xì),所以今天就...
    熊孩子CEO閱讀 469評(píng)論 0 0
  • 作者的序言 朋友們,棄療系列4出來(lái)啦,作者還并沒(méi)有放棄,感覺(jué)自己萌萌噠,233。 語(yǔ)句 js程序其實(shí)就是一系列可執(zhí)...
    zhaolion閱讀 1,821評(píng)論 0 8
  • 條件語(yǔ)句 if(條件){語(yǔ)句1;}else{語(yǔ)句2;}條件為true,則取語(yǔ)句1,false則取語(yǔ)句2. var ...
    olivia1111閱讀 347評(píng)論 0 0
  • “我的天空總是掛著......”我很喜歡的王菲的一首歌一響起,換腦子的初衷就被抹掉了,只能感覺(jué)到灰色重疊的憋悶感。...
    蛇神閱讀 233評(píng)論 0 1
  • 靜靜手繪頭像,不會(huì)讓你失望的。你發(fā)自拍,我來(lái)畫
    靜靜手繪閱讀 205評(píng)論 3 6

友情鏈接更多精彩內(nèi)容