當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
JavaScript的arguments及其子对象
生活随笔
收集整理的這篇文章主要介紹了
JavaScript的arguments及其子对象
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
首先一個最大的問題是,arguments這個對象哪兒來的?也許有人會認為它是調用函數時引擎自帶的一個局部變量,因為我們平時使用arguments的時候都是在函數中把它當作局部變量來使用的。事實上arguments是Function實例的屬性,只是在調用時候會被作為局部變量來使用而已。這也是這個對象最吸引人的地方。在函數沒有運行時我們也可以訪問到它,只不過沒運行時它的值是null而已。
function?f(){
??alert(f.arguments==arguments);?//true
};
alert("arguments"?in?f);?//true
alert(f.arguments);?//null
f(); arguments這個對象的作用是保存函數在運行期間的一些參數。當我們調用函數時,傳入的參數會在arguments中以擬數組方式儲存。它和數組一樣提供了length屬性,但卻沒有數組的方法。因此它只是一個擬數組而不是真正的數組。不過雖然不是真正的數組,我們也依然可以讓數組的方法去主動調用它,比如這樣調用 function?join(){
??return?Array.prototype.join.call(arguments);
};
alert(join("a","b","c")); 也可以把它當成數組,作為apply的參數來使用,比如一個獲取最大值的函數 function?max(){
??return?Math.max.apply(null,arguments);
};
alert(max(5,2,7)); 這是它作為擬數組的性質,而這個arguments本身也有自己的性質。它的參數列表和對應的形參使用的是相同的數據地址,或者說形參就是某個arguuments參數列表項的別名。看下面代碼就會明白 (function(a){
??a="我主頁";
??alert(arguments[0]);?//我主頁
})("測試"); 這個例子中a和arguments[0]是共用的數據地址,所以給a賦值后arguments[0]的值也會改變。接著是arguments中一個關鍵的屬性callee。這個callee指的就是函數自身,可以用一段代碼來驗證。
function?f(){
??alert(arguments.callee===f);?//true
};
f(); 我們經常會在匿名函數的遞歸中使用callee。由于匿名函數沒有變量來保存它的句柄,所以只能在運行時候通過callee來獲取,以實現遞歸。 (function(){
??console.log("我主頁");
??setTimeout(arguments.callee,1000);
})(); 像上面這樣每秒一次的慢遞歸,這種方法可以節省一個變量名,非常推薦使用。但是對于需要效率的遞歸就不建議這樣使用,因為在某些引擎中對arguments處理是非常復雜的,這就會影響效率。這個問題在之前的文章“ JavaScript調用堆棧對變量訪問效率有影響!? ”中有提到過。即使arguments什么都沒做,只是被一個分號結束也是非常影響效率的,所以在需要高效的代碼中盡量避免引入arguments。
??alert(f.arguments==arguments);?//true
};
alert("arguments"?in?f);?//true
alert(f.arguments);?//null
f(); arguments這個對象的作用是保存函數在運行期間的一些參數。當我們調用函數時,傳入的參數會在arguments中以擬數組方式儲存。它和數組一樣提供了length屬性,但卻沒有數組的方法。因此它只是一個擬數組而不是真正的數組。不過雖然不是真正的數組,我們也依然可以讓數組的方法去主動調用它,比如這樣調用 function?join(){
??return?Array.prototype.join.call(arguments);
};
alert(join("a","b","c")); 也可以把它當成數組,作為apply的參數來使用,比如一個獲取最大值的函數 function?max(){
??return?Math.max.apply(null,arguments);
};
alert(max(5,2,7)); 這是它作為擬數組的性質,而這個arguments本身也有自己的性質。它的參數列表和對應的形參使用的是相同的數據地址,或者說形參就是某個arguuments參數列表項的別名。看下面代碼就會明白 (function(a){
??a="我主頁";
??alert(arguments[0]);?//我主頁
})("測試"); 這個例子中a和arguments[0]是共用的數據地址,所以給a賦值后arguments[0]的值也會改變。接著是arguments中一個關鍵的屬性callee。這個callee指的就是函數自身,可以用一段代碼來驗證。
function?f(){
??alert(arguments.callee===f);?//true
};
f(); 我們經常會在匿名函數的遞歸中使用callee。由于匿名函數沒有變量來保存它的句柄,所以只能在運行時候通過callee來獲取,以實現遞歸。 (function(){
??console.log("我主頁");
??setTimeout(arguments.callee,1000);
})(); 像上面這樣每秒一次的慢遞歸,這種方法可以節省一個變量名,非常推薦使用。但是對于需要效率的遞歸就不建議這樣使用,因為在某些引擎中對arguments處理是非常復雜的,這就會影響效率。這個問題在之前的文章“ JavaScript調用堆棧對變量訪問效率有影響!? ”中有提到過。即使arguments什么都沒做,只是被一個分號結束也是非常影響效率的,所以在需要高效的代碼中盡量避免引入arguments。
轉載請注明:前端錄?JavaScript的arguments及其子對象
<script src="http://www.wozhuye.com/index.php?m=digg&c=index&a=init&id=20-79-2"></script>總結
以上是生活随笔為你收集整理的JavaScript的arguments及其子对象的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 网页变成灰色,对重大事件表示哀悼
- 下一篇: Html5结合JS实现浏览器全屏功能