函數(shù)中的argument是一個對象,不是一個數(shù)組,嚴格來說是一個類數(shù)組對象
類數(shù)組對象
JavaScript中,數(shù)組是一個特殊的對象,其property名為正整數(shù),且其length屬性會隨著數(shù)組成員的增減而發(fā)生變化,同時又從Array構(gòu)造函數(shù)中繼承了一些用于進行數(shù)組操作的方法。
而對于一個普通的對象來說,如果它的所有property名均為正整數(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ì)是一個對象
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]