JavaScript高級程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記5 js語句
語句一覽
| 語句 | 語法 | 簡要描述 |
| 簡單語句 |
; |
語句以分號(;)結(jié)束,在不引起歧義的情況下也可以省略分號。 |
| 語句塊 |
{} |
使用大括號({})將一組語句放一起組成一個(gè)語句塊,在ECMAScript中,有語句塊,但沒有語句塊作用域。 |
| if語句 |
if(condition){} if(ocndition){}else{} |
條件選擇,在條件表達(dá)式中,會(huì)將結(jié)果隱式轉(zhuǎn)換為Boolean類型。 建議每個(gè)分支都明確使用{},以避免維護(hù)時(shí)出錯(cuò)。 條件語句可以嵌套。 |
| switch語句 |
switch(expression) { case value1: statement1; break; case value2: statement2; break; default: statement; break; } |
switch語句語法和C語言一致,不同的是,switch中的expression不限于整型。 1、在switch語句中,表達(dá)式不限于整型,可以是任意表達(dá)式。 2、在case后面的value中,可以是整型,也可以是其它類型,甚至可以是一個(gè)表達(dá)式,但是在比較的時(shí)候不會(huì)進(jìn)行類型轉(zhuǎn)換,也即是使用全等(===)進(jìn)行匹配。 3、case分支中的break表示不再繼續(xù)后面的匹配,如果省略了會(huì)繼續(xù)執(zhí)行下面的case語句。建議每個(gè)case都加上break,如果是利用這種繼續(xù)執(zhí)行的特性,也加上相應(yīng)注釋說明。 4、最后一個(gè)分支的break加不加效果相同,我自己的個(gè)人風(fēng)格是加上保持一致性。 |
| do-while語句 |
do{ statement; }while(expression); |
先執(zhí)行循環(huán)體,再進(jìn)行條件判斷,這種格式至少會(huì)執(zhí)行一次循環(huán)。 條件判斷也會(huì)有隱式轉(zhuǎn)換。 |
| while語句 |
while(expression) { statement; } |
滿足條件才執(zhí)行循環(huán)體。如果一開始就不滿足條件,則根本不會(huì)執(zhí)行循環(huán)體。 |
| for語句 |
for(initialization; expression; post-loop-expression){ statement; } |
for語句在功能上和while是等價(jià)的。 執(zhí)行順序是,先執(zhí)行初始化initialization,然后進(jìn)行條件比較expression,如果滿足條件,就執(zhí)行循環(huán)體,執(zhí)行完一次循環(huán)后,執(zhí)行post-loop-expression部分,然后循環(huán)比較條件直至跳出整個(gè)循環(huán)。 |
| for-in語句 |
for(property in expression){ statement; } |
for循環(huán)的另一種形式,可以使用這種循環(huán)遍歷對象的屬性和對象原型鏈上的屬性。 |
| with語句 |
with(expression){ statement; } |
將代碼的作用域設(shè)置到一個(gè)特定的對象中。 |
| label語句 | label:statement; | 給代碼添加標(biāo)簽供其它語句使用。 |
| break語句 |
break; break label; |
1、用在switch語句中,在找到匹配的case分支后,不繼續(xù)執(zhí)行下面的case語句。 2、用在循環(huán)語句中中斷整個(gè)循環(huán)。 |
| continue語句 |
continue; continue label; |
在循環(huán)語句中中斷本次循環(huán),執(zhí)行下一次循環(huán)。 |
| try語句 |
try{ }catch(e){ }finally{ } |
將代碼放在try塊中,使得異常發(fā)生時(shí)能夠做出相應(yīng)的處理。 |
| throw語句 | throw e; | 拋出異常。 |
| debugger語句 | debugger; | 調(diào)試。 |
| return語句 |
return; return expression; |
返回語句。在return之后沒有返回時(shí),返回undefined。 |
對于語句,說明如下:
1、關(guān)于語句要不要加上分號結(jié)束符(;),我的觀點(diǎn)是給每條語句都加上,不要讓引擎去猜測你的程序。不過昨天看到一篇文章和我的觀點(diǎn)正好相反,也頗能言之成理,雖然并沒有改變我的觀點(diǎn),不過倒也令我的眼界更為寬闊。
2、對于var語句,由于ECMAScript中有聲明提升現(xiàn)象,建議將一個(gè)作用域中用到的變量都放到頂部,用一個(gè)var語句定義多個(gè)變量,這樣容易理解,也不易出錯(cuò)。目前很多JS庫也多采用這種形式,下面是取自jQuery開始中的代碼:
var document = window.document,
navigator = window.navigator,
location = window.location;
3、用于語句塊的({}),也可用于定義對象字面量。在ECMAScript中,沒有塊級作用域。
4、對于四種循環(huán)語句(do-while、while、for、for-in),由于for-in語句每次循環(huán)都會(huì)搜索對象本身和其原型,因此效率會(huì)比較低。關(guān)于for循環(huán)語句的優(yōu)化:
// 1.一般for循環(huán)
for(var i=0; i < arr.length; i++){
}
// 2.上面在每一次循環(huán)都會(huì)重新計(jì)算一次arr的長度,如過arr是dom操作的話,會(huì)非常明顯的影響效率,可以改進(jìn)一下
for(var i=0,l=arr.length; i<l; i++){
}
// 3.這樣整個(gè)循環(huán)就只會(huì)計(jì)算一次長度,如果考慮到遞減,還可以修改成
for(var i=arr.length; i>0; i--){
}
// 4.上面不使用中間變量并且只需要計(jì)算一次長度,如果再考慮到長度永遠(yuǎn)是一個(gè)不小于0的數(shù),并且在JS中0的Boolean值為false,可以進(jìn)一步修改成
for(var i=arr.length; i ; i--){
}
// 5.考慮到JS中變量聲明提升可能的影響,為了消除隱患,再修改為
var i=arr.length;
for(; i ; i--){
}
5、對于with語句,雖然有時(shí)會(huì)提供快捷,但是也常常會(huì)導(dǎo)致不可預(yù)料的結(jié)果,建議少用,甚至不用:
//1.使用with語句
with(obj){
a=b;
}
//2.不使用with語句,和1的情況等價(jià)
if(obj.a === undefined){
a = obj.b || b;
}else
{
obj.a = obj.b || b;
}
//3.可能的結(jié)果
a = b;
a = obj.b;
obj.a = b;
obj.a = obj.b;
第1部分是使用with語句,第2部分是不使用with語句的等價(jià)語句,第3部分則是最終可能的運(yùn)行結(jié)果,如果僅從with語句本身來看,很不容易明白程序?qū)嶋H運(yùn)行時(shí)會(huì)發(fā)生什么。另外,在使用with語句涉及修改的時(shí)候,會(huì)有不同步的問題,看下面的代碼:
var obj = {
person:{
name:'linjisong'
}
};
with(obj.person){
obj.person = {
name:'oulinhai'
};
console.info(obj.person.name); //oulinhai
console.info(name); //linjisong
}
在這里會(huì)不經(jīng)意間就產(chǎn)生了一個(gè)不同步。
6、在return語句返回時(shí)需注意:
return
{
prop:'value';
}//由于引擎會(huì)自動(dòng)添加分號,這里實(shí)際會(huì)返回undefined
return {
prop:'value';
}//返回一個(gè)對象
- javascript中類的定義及其方式(《javascript高級程序設(shè)計(jì)》學(xué)習(xí)筆記)
- JavaScript高級程序設(shè)計(jì) DOM學(xué)習(xí)筆記
- JavaScript高級程序設(shè)計(jì) XML、Ajax 學(xué)習(xí)筆記
- JavaScript高級程序設(shè)計(jì) 事件學(xué)習(xí)筆記
- JavaScript高級程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記 概述
- JavaScript高級程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記2 js基礎(chǔ)語法
- JavaScript高級程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記3 js簡單數(shù)據(jù)類型
- JavaScript高級程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記4 js運(yùn)算符和操作符
- JavaScript高級程序設(shè)計(jì)(第三版)學(xué)習(xí)筆記1~5章
相關(guān)文章
JavaScript 關(guān)于事件循環(huán)機(jī)制的刨析
js里的事件循環(huán)機(jī)制十分有趣。從很多面試題也可以看出來,考察簡單的setTimeout也就是考察這個(gè)機(jī)制的,接下來本文帶你詳細(xì)了解它2021-11-11
JavaScript DOM 學(xué)習(xí)第五章 表單簡介
在這一章我主要介紹一些用來檢測用戶輸入的代碼,利用這些代碼,你也可以寫一些自己的檢測函數(shù)。2010-02-02
JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧與隊(duì)列
在面向?qū)ο蟮某绦蛟O(shè)計(jì)里,一般都提供了實(shí)現(xiàn)隊(duì)列(queue)和堆棧(stack)的方法,而對于JS來說,我們可以實(shí)現(xiàn)數(shù)組的相關(guān)操作,來實(shí)現(xiàn)隊(duì)列和堆棧的功能,看下面的相關(guān)介紹.2016-01-01
javascript 內(nèi)置對象及常見API詳細(xì)介紹
這篇文章主要介紹了javascript 內(nèi)置對象及常見API的相關(guān)資料,這里對內(nèi)置對象進(jìn)行了詳細(xì)的整理,需要的朋友可以參考下2016-11-11

