函數(shù)中的argument是一個(gè)對象攒庵,不是一個(gè)數(shù)組,嚴(yán)格來說是一個(gè)類數(shù)組對象
類數(shù)組對象
JavaScript中败晴,數(shù)組是一個(gè)特殊的對象浓冒,其property名為正整數(shù),且其length屬性會隨著數(shù)組成員的增減而發(fā)生變化尖坤,同時(shí)又從Array構(gòu)造函數(shù)中繼承了一些用于進(jìn)行數(shù)組操作的方法稳懒。
而對于一個(gè)普通的對象來說,如果它的所有property名均為正整數(shù)慢味,同時(shí)也有相應(yīng)的length屬性场梆,那么雖然該對象并不是由Array構(gòu)造函數(shù)所創(chuàng)建的墅冷,它依然呈現(xiàn)出數(shù)組的行為,在這種情況下或油,這些對象被稱為“類數(shù)組對象”
可以使用數(shù)組中的方法寞忿,例如可以使用slice()方法獲取類數(shù)組對象上的子數(shù)組,可以使用join方法來連接成為數(shù)組顶岸。
例如
var leiarr={0:42,1:52,2:63,length:3}
類數(shù)組對象不能調(diào)用數(shù)組原型上的方法腔彰,它本質(zhì)是一個(gè)對象
var fn=function(b,c){
return Object.prototype.toString.call(arguments)
}
console.log(fn(3,4))//[object Arguments]
調(diào)用數(shù)組的原型方法來轉(zhuǎn)換
var fn=function(b,c){
var arr=Array.prototype.slice.call(arguments);
console.log(arr)
}
fn(3,4,5);//[3,4,5]
調(diào)用ES6中的Array from來轉(zhuǎn)換
Array from方法用于將兩類對象轉(zhuǎn)為真正的數(shù)組:類似數(shù)組的對象和可遍歷對象(例如有Set和Map)
var fn =function(b,c){
var arr=Array.from(arguments);
console.log(arr);
}
fn(3,4,5)[3,4,5]