首頁 >web前端 >js教程 >JavaScript高階程式設計(第3版)學習筆記5 js語句_基礎知識

JavaScript高階程式設計(第3版)學習筆記5 js語句_基礎知識

WBOY
WBOY原創
2016-05-16 17:49:13930瀏覽

砖瓦和水泥都有了,接下来该是砌墙了,在ECMAScript中,语句就是我们需要砌的墙了。语句也和操作符一样,对于有C背景的人来说再自然不过了,下面采用类似的形式整理一下语句的相关知识,重点突出一些ECMAScript中比较特别和个人认为比较有意思的地方,同样,没有强调的但比较基础的语句并非不重要,而是我认为你已经熟悉。

语句一览

语句 语法 简要描述
简单语句

 ;

语句以分号(;)结束,在不引起歧义的情况下也可以省略分号。

语句块

{}

使用大括号({})将一组语句放一起组成一个语句块,在ECMAScript中,有语句块,但没有语句块作用域。

if语句

if(condition){}

if(ocndition){}else{}

条件选择,在条件表达式中,会将结果隐式转换为Boolean类型。

建议每个分支都明确使用{},以避免维护时出错。

条件语句可以嵌套。

switch语句

switch(expression)

{

case value1:

  statement1;

  break;

case value2:

  statement2;

  break;

default:

  statement;

  break;

}

switch语句语法和C语言一致,不同的是,switch中的expression不限于整型。

1、在switch语句中,表达式不限于整型,可以是任意表达式。

2、在case后面的value中,可以是整型,也可以是其它类型,甚至可以是一个表达式,但是在比较的时候不会进行类型转换,也即是使用全等(===)进行匹配。

3、case分支中的break表示不再继续后面的匹配,如果省略了会继续执行下面的case语句。建议每个case都加上break,如果是利用这种继续执行的特性,也加上相应注释说明。

4、最后一个分支的break加不加效果相同,我自己的个人风格是加上保持一致性。

do-while语句

do{

  statement;

}while(expression);

先执行循环体,再进行条件判断,这种格式至少会执行一次循环。

条件判断也会有隐式转换。

while语句

while(expression)

{

  statement;

}

满足条件才执行循环体。如果一开始就不满足条件,则根本不会执行循环体。

for语句

for(initialization; expression; post-loop-expression){

  statement;

}

for语句在功能上和while是等价的。

执行顺序是,先执行初始化initialization,然后进行条件比较expression,如果满足条件,就执行循环体,执行完一次循环后,执行post-loop-expression部分,然后循环比较条件直至跳出整个循环。

for-in语句

for(property in expression){

  statement;

}

for循环的另一种形式,可以使用这种循环遍历对象的属性和对象原型链上的属性。

with语句

with(expression){

  statement;

}

将代码的作用域设置到一个特定的对象中。

label语句 label:statement; 给代码添加标签供其它语句使用。
break语句

break;

break label;

1、用在switch语句中,在找到匹配的case分支后,不继续执行下面的case语句。

2、用在循环语句中中断整个循环。

continue语句

continue;

continue label;

在循环语句中中断本次循环,执行下一次循环。

try语句

try{

}catch(e){

}finally{

}

将代码放在try块中,使得异常发生时能够做出相应的处理。

throw语句 throw e;  抛出异常。
debugger语句 debugger; 调试。
return语句

return;

return expression;

返回语句。在return之后没有返回时,返回undefined。

對於語句,說明如下:

1、關於語句要不要加上分號結束符號(;),我的觀點是給每個語句都加上,不要讓引擎去猜測你的程式。不過昨天看到一篇文章和我的觀點正好相反,也頗能言之成理,雖然並沒有改變我的觀點,不過倒也令我的眼界更為寬闊。

2、對於var語句,由於ECMAScript中有聲明提升現象,建議將一個作用域中用到的變數都放到頂部,用一個var語句定義多個變量,這樣容易理解,也不易出錯。目前許多JS函式庫也多採用這種形式,以下是取自jQuery開始中的程式碼:

複製程式碼代碼如下:

var document = window.document,
navigator = window.navigator,
location = window.location;

location = window.location;

3、用於🎜> 3、用於🎜> 語句塊的({}),也可用來定義物件字面量。在ECMAScript中,沒有區塊級作用域。 4、對於四個迴圈語句(do-while、while、for、for-in),由於for-in語句每次迴圈都會搜尋物件本身和其原型,因此效率會比較低。關於for迴圈語句的最佳化:


複製程式碼


程式碼如下:


/// 1.一般for迴圈
for(var i=0; i }
// 2.上面每一次迴圈會重新計算一次arr的長度,如過arr是dom操作的話,會非常明顯的影響效率,可以改進一下
for(var i=0,l=arr.length; i}
// 3.這樣整個循環就只會計算一次長度,如果考慮到遞減,還可以修改成
for(var i=arr.length; i>0; i--){
}
// 4.上面不使用中間變數並且只需要計算一次長度,如果再考慮到長度永遠是一個不小於0的數,並且在JS中0的Boolean值為false,可以進一步修改成
for(var i=arr.length ; i ; i--){
}
// 5.考慮JS中變數宣告提升可能的影響,為了消除隱患,再修改為
var i=arr.length; for(; i ; i--){ } 5、對於with語句,雖然有時會提供快捷,但是也常常會導致不可預料的結果,建議少用,甚至不用:


複製程式碼


程式碼如下:


//1.使用語句


//1.使用語句


//1.使用語句


//1.使用語句


//1.使用語句{
obj.a = obj.b || b;
}
//3.可能的結果
a = b;
a = obj.b;
obj.a = b;
obj.a = obj.b;


第1部分是使用with語句,第2部分是不使用with語句的等價語句,第3部分則是最終可能的運行結果,如果僅從with語句本身來看,很不容易明白程式實際運行時會發生什麼。另外,使用with語句涉及修改的時候,會有不同步的問題,看下面的程式碼:



複製程式碼


程式碼如下:with(obj.person){
obj.person = {
name:'oulinhai'
};
console.info(obj.person.name); //oulinhai
console.info(name);   //linjisong
}


在這裡會不經意間就產生了一個不同步。
6.在return語句回傳時要注意:
複製程式碼 程式碼如下: >return { prop:'value'; }//由於引擎會自動加分號,這裡實際上會回傳undefined return { prop:'value' ; }//回傳一個物件
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn