Javascript中arguments對(duì)象的詳解與使用方法
一、arguments使用方法
通過(guò)方括號(hào)語(yǔ)法訪問(wèn)每一個(gè)元素
var fun = function(one) { console.log(arguments[0]); console.log(arguments[1]); console.log(arguments[2]); } fun(1, 2, 3) // 1 // 2 // 3
通過(guò)length
屬性,查看到底要幾個(gè)參數(shù)
function fun() { return arguments.length; } fun(1, 2, 3) // 3 fun(1) // 1 fun() // 0
參數(shù)賦值(“嚴(yán)格模式下不允許”)
var fun = function(a, b) { arguments[1] = 2; return a + b; } fun(1, 1) // 3
二、arguments與數(shù)組的關(guān)系
雖然arguments可以使用中括號(hào)語(yǔ)法,并且具有length
屬性,但arguments對(duì)象只是與數(shù)組類似,并不是Array
的實(shí)例。因此,無(wú)法對(duì) arguments 變量使用標(biāo)準(zhǔn)的數(shù)組方法,比如 push, pop 或者 slice。 雖然使用 for
循環(huán)遍歷也是可以的,但是為了更好的使用數(shù)組方法,最好把它轉(zhuǎn)化為一個(gè)真正的數(shù)組。
如何使用數(shù)組方法?
通過(guò)apply
方法,把a(bǔ)rguments作為參數(shù)傳進(jìn)去,這樣就可以讓arguments使用數(shù)組方法了。
// 用于apply方法 myFunction.apply(obj, arguments). // 使用與另一個(gè)數(shù)組合并 Array.prototype.concat.apply([1,2,3], arguments)
終極解決方法,直接轉(zhuǎn)為真正的數(shù)組
下面的代碼將會(huì)創(chuàng)建一個(gè)新的數(shù)組,包含所有 arguments 對(duì)象中的元素。
var args = Array.prototype.slice.call(arguments); //或者 var args = []; for (var i = 0; i < arguments.length; i++) { args.push(arguments[i]); } //或者 var args = [].slice.call(arguments, 0);
三、強(qiáng)大卻不建議使用的callee屬性
arguments的callee
屬性可以調(diào)用函數(shù)本身,當(dāng)函數(shù)正在執(zhí)行時(shí)才可調(diào)用,可以實(shí)現(xiàn)方法的遞歸調(diào)用
下面的代碼將會(huì)實(shí)現(xiàn)一個(gè)求階乘方法
var factorial = function(x){ return x<=1?1:x*arguments.callee(x-1); }
在ECMAScript5嚴(yán)格模式中,對(duì)這個(gè)屬性的讀寫(xiě)操作會(huì)產(chǎn)生一個(gè)類型錯(cuò)誤,并且會(huì)顯著的影響現(xiàn)代 JavaScript 引擎的性能,所以,因此強(qiáng)烈建議大家不要使用 arguments.callee
和它的屬性。
四、總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)和工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
JS實(shí)現(xiàn)動(dòng)態(tài)增加和刪除li標(biāo)簽行的實(shí)例代碼
下面小編就為大家?guī)?lái)一篇JS實(shí)現(xiàn)動(dòng)態(tài)增加和刪除li標(biāo)簽行的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10基于JavaScript實(shí)現(xiàn)前端數(shù)據(jù)多條件篩選功能
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)前端數(shù)據(jù)多條件篩選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09javascript動(dòng)態(tài)創(chuàng)建鏈接的方法
這篇文章主要介紹了javascript動(dòng)態(tài)創(chuàng)建鏈接的方法,涉及javascript動(dòng)態(tài)操作頁(yè)面元素的技巧,需要的朋友可以參考下2015-05-05JavaScript中l(wèi)ocalStorage對(duì)象存儲(chǔ)方式實(shí)例分析
這篇文章主要介紹了JavaScript中l(wèi)ocalStorage對(duì)象存儲(chǔ)方式,結(jié)合實(shí)例形式分析了localStorage對(duì)象存儲(chǔ)數(shù)據(jù)的原理及操作技巧,需要的朋友可以參考下2017-01-01bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例
這篇文章主要介紹了bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03JS繪圖Flot如何實(shí)現(xiàn)可選顯示曲線圖功能
這篇文章主要介紹了JS繪圖Flot如何實(shí)現(xiàn)可選顯示曲線圖功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10下載網(wǎng)站打開(kāi)頁(yè)面后間隔多少時(shí)間才顯示下載鏈接地址的代碼
有時(shí)候可能為了一些更好的廣告效果等原因,需要讓用戶等待一段時(shí)間以后,再顯示真實(shí)下載地址代碼,有利于緩解服務(wù)器壓力。2010-04-04