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