標籤:
對於語句,說明如下:
1、關於語句要不要加上分號結束符(;),我的觀點是給每條語句都加上,不要讓引擎去猜測你的程式。不過昨天看到一篇文章和我的觀點正好相反,也頗能言之成理,雖然並沒有改變我的觀點,不過倒也令我的眼界更為寬闊。
2、對於var語句,由於ECMAScript中有聲明提升現象,建議將一個範圍中用到的變數都放到頂部,用一個var語句定義多個變數,這樣容易理解,也不易出錯。目前很多JS庫也多採用這種形式,下面是取自jQuery開始中的代碼:
var document = window.document, navigator = window.navigator, location = window.location;
3、用於語句塊的({}),也可用於定義對象字面量。在ECMAScript中,沒有塊級範圍。
4、對於四種迴圈語句(do-while、while、for、for-in),由於for-in語句每次迴圈都會搜尋對象本身和其原型,因此效率會比較低。關於for迴圈語句的最佳化:
// 1.一般for迴圈for(var i=0; i < arr.length; i++){}// 2.上面在每一次迴圈都會重新計算一次arr的長度,如過arr是dom操作的話,會非常明顯的影響效率,可以改進一下for(var i=0,l=arr.length; i<l; 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.使用with語句with(obj){ a=b;}//2.不使用with語句,和1的情況等價if(obj.a === undefined){ a = obj.b || b;}else{ 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語句涉及修改的時候,會有不同步的問題,看下面的代碼:
var obj = { person:{ name:‘linjisong‘ } };with(obj.person){ obj.person = { name:‘oulinhai‘ }; console.info(obj.person.name); //oulinhai console.info(name); //linjisong}在這裡
會不經意間就產生了一個不同步。
6、在return語句返回時需注意:
return{ prop:‘value‘;}//由於引擎會自動添加分號,這裡實際會返回undefinedreturn { prop:‘value‘;}//返回一個對象
javascript中語句注意點