再學JS--類數(shù)組對象與arguments

類數(shù)組對象

所謂的類數(shù)組對象:擁有一個length屬性和若干索引屬性的對象

var arr = ['name', 'age', 'sex']

var arrLike = {
    0: 'name',
    1: 'age',
    2: 'sex',
    length: 3
}

我們從讀寫、獲取長度蹂随、遍歷三個方面看看這兩個對象。

讀寫

console.log(arr[0])  // name
console.log(arrLike[0])  // name

arr[0] = 'new name'
arrLike[0] = 'new name'

長度

console.log(arr.length)  // 3
console.log(arrLike.length)  // 3

遍歷

for(var i = 0, len = arr.length; i<len; i++) {
    console.log(arr[i])
    // name age sex
}

for(var i = 0, len = arrLike.length; i<len; i++) {
    console.log(arr[i])
    // name age sex
}

調用數(shù)組方法

類數(shù)組可以調用數(shù)組的方法嗎即供?

arrLike.push('city')
// arrLike is not a function

類數(shù)組無法直接調用數(shù)組方法,我們可以用Function.call間接調用

console.log(Array.prototype.join.call(arrLike, '&'))  // name&age&sex
console.log(Array.prototype.slice.call(arrLike)) // ['name','age','sex']
// slice可以做到類數(shù)組轉數(shù)組
console.log(Array.prototype.map.call(arrLike, function(item){
    return item.toUpperCase()
}))  // ['NAME','AGE','SEX']

類數(shù)組轉數(shù)組

上面的例子已經(jīng)提到一種類數(shù)組轉數(shù)組的方法尼啡,再補充完善下:

console.log(Array.prototype.slice.call(arrLike))
console.log(Array.prototype.splice.call(arrLike, 0))
// ES6
console.log(Array.from(arrLike))
console.log(Array.prototype.concat.apply([], arrLike))

Arguments對象

Arguments對象就是一個類數(shù)組對象,Arguments對象只定義在函數(shù)體內询微,包括了函數(shù)的參數(shù)和其他參數(shù)崖瞭。在函數(shù)體中,arguments指代該函數(shù)的Arguments對象撑毛。

function foo(name, age, sex) {
    console.log(arguments)
}
foo('name', 'age', 'sex')

打印結果:

image-20200512095611667

我們看到除了類數(shù)組的索引屬性和length屬性之外读恃,還有一個callee屬性代态。

length屬性

Arguments對象的length屬性,表示實參的長度

function foo(name, age, sex) {
    // 實參長度
    console.log(arguments.length)  // 1
}
// 形參長度
console.log(foo.length)  // 3
foo('name')

callee屬性

Arguments對象的callee屬性疹吃,通過它可以調用函數(shù)自身蹦疑。

通過下面閉包的例子來看下callee的解決方法:

var data = []
for(var i = 0; i < 3; i++) {
    (data[i] = function() {
        console.log(arguments.callee.i)
    }). i = i
}
console.log(data[0].i)  // 0
console.log(data[1].i)  // 1
console.log(data[2].i)  // 2

arguments和對象參數(shù)的綁定

function foo(name, age, sex, hobbit) {
    console.log(name, arguments[0])  // name, name
    // 改變形參
    arguments[0] = 'new name'
    console.log(name, arguments[0])  // new name, new name
    // 改變arguments
    arguments[1] = 'new age'
    console.log(name, arguments[1])  // new name, new age
    // 未傳入的是否會被綁定
    sex = 'new sex'
    console.log(sex, arguments[2]) // undefined, new sex
    arguments[3] = 'new hobbit'
    console.log(hobbit, arguments[3])  //  undefined, new hobbit
}

foo('name', 'age')

傳入的參數(shù),實參和arguments的值會被共享萨驶,當沒有傳入的時候歉摧,實參與arguments不會共享。

以上都是非嚴格模式下腔呜,在嚴格模式下叁温,實參和arguments是不會共享的

傳遞參數(shù)

將參數(shù)從一個函數(shù)傳遞到另一個函數(shù)

function foo(){
    bar.apply(this, arguments)
}
function bar(a,b,c){
    console.log(a,b,c)
}
foo(1,2,3)  // 1,2,3

ES6展開運算符

function func(...arguments) {
    console.log(arguments)
}
func(1,2,3)  // 1,2,3

應用

arguments的應用其實很多核畴,例如:

  1. 參數(shù)不定長
  2. 函數(shù)柯里化
  3. 遞歸調用
  4. 函數(shù)重載
  5. ......
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末膝但,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子谤草,更是在濱河造成了極大的恐慌跟束,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丑孩,死亡現(xiàn)場離奇詭異冀宴,居然都是意外死亡,警方通過查閱死者的電腦和手機温学,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門略贮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人仗岖,你說我怎么就攤上這事逃延。” “怎么了轧拄?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵真友,是天一觀的道長。 經(jīng)常有香客問我紧帕,道長盔然,這世上最難降的妖魔是什么桅打? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮愈案,結果婚禮上挺尾,老公的妹妹穿的比我還像新娘。我一直安慰自己站绪,他們只是感情好遭铺,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著恢准,像睡著了一般魂挂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上馁筐,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天涂召,我揣著相機與錄音,去河邊找鬼敏沉。 笑死果正,一個胖子當著我的面吹牛,可吹牛的內容都是我干的盟迟。 我是一名探鬼主播秋泳,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼攒菠!你這毒婦竟也來了迫皱?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤辖众,失蹤者是張志新(化名)和其女友劉穎舍杜,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赵辕,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡既绩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了还惠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饲握。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖蚕键,靈堂內的尸體忽然破棺而出救欧,到底是詐尸還是另有隱情,我是刑警寧澤锣光,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布笆怠,位于F島的核電站,受9級特大地震影響誊爹,放射性物質發(fā)生泄漏蹬刷。R本人自食惡果不足惜瓢捉,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望办成。 院中可真熱鬧泡态,春花似錦、人聲如沸迂卢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽而克。三九已至靶壮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間员萍,已是汗流浹背腾降。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留充活,地道東北人。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓蜡娶,卻偏偏與公主長得像混卵,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子窖张,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348