鍍金池/ 問答/網(wǎng)絡(luò)安全  HTML/ 關(guān)于call()方法的一點疑問?

關(guān)于call()方法的一點疑問?

function ArrayOf(){ 
  return [].slice.call(arguments); 
} 

這個函數(shù)式是實現(xiàn)將arguments轉(zhuǎn)換成數(shù)組。
但是我有個疑問就是這個call()方法不是第一個參數(shù)不是指向this對象嗎?為啥這個表達式[].slice.call(arguments)中,我感覺arguments怎么變成了參數(shù)了傳入到空數(shù)組中了?
實在不知道這個實現(xiàn)原理?有沒有大佬能讓我醍醐灌頂

回答
編輯回答
鐧簞噯

functionName.call的參數(shù)是(綁定對象,方法參數(shù)),相當于綁定對象.functionName(方法參數(shù))。 對應(yīng)本例,arguments這個數(shù)組做了綁定對象,相當于執(zhí)行了arguments.slice()[].slice只是表示借用了數(shù)組的slice方法。

PS.深挖一下,其實slice這個方法實現(xiàn)中應(yīng)該有個this,使用call(綁定對象)的方式調(diào)用它,綁定對象會充當這個this(這是call或apply真正干的事情),看例子,一看就懂

function addAge() {
    this.age = 18;
}
let boy = {};
addAge.call(boy);
console.log(boy.age); //18
2017年4月30日 05:21
編輯回答
赱丅呿

[].slice 是在獲取 slice 方法

function ArrayOf() {
    const slice = [].slice
    return slice.call(arguments)
}

這么看你就明白了。

2018年1月14日 04:52
編輯回答
熟稔

給類數(shù)組 arguments 調(diào)用Array 的方法 slice, 使其變?yōu)檎嬲臄?shù)組

可以稱為方法借用, [].slice 是一個方法, 借給 arguments 用用, 得到 arugments 的數(shù)組副本

2017年6月25日 12:57