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)化多次編寫(xiě)同一個(gè)對(duì)象的工作,嚴(yán)格模式下不允許使用with語(yǔ)句

由于大量使用with語(yǔ)句會(huì)導(dǎo)致性能下降,同時(shí)也會(huì)給調(diào)試代碼造成困難,因此開(kāi)發(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)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,155評(píng)論 3 425
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 177,635評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,539評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,255評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,646評(píng)論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,838評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,399評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,146評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,338評(píng)論 1 372
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,565評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,983評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,257評(píng)論 1 292
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,059評(píng)論 3 397
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,296評(píng)論 2 376

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