call()和apply()是每個函數(shù)都包含的非繼承來的方法,其作用是在特定的作用域中調(diào)用函數(shù),call()和apply()方法的用法基本相同,區(qū)別僅僅在于參數(shù)的寫法上。
apply()方法
apply()方法包含兩個參數(shù),(this,argument)依次為 在其中運(yùn)行函數(shù)的作用域,參數(shù)集合,其中第二個參數(shù)可以為一個數(shù)組或者是arguments對象
function sum(num1,num2){
return num1+num2;
}
function apply(num1,num2){
return sum.apply(this,arguments);
return sum.apply(this,[num1,num2]); //兩種寫法都可以
}
console.log(apply(1,2)); //3
call()方法
apply()方法包含兩個參數(shù),(this,num1,num2,...)依次為 在其中運(yùn)行函數(shù)的作用域,需要一一列舉出來的參數(shù)集合,不同于apply()第二個參數(shù)以集合的方式呈現(xiàn),call()方法的第二個參數(shù)集合必須要一一列舉出來。
function sum(num1,num2){
return num1+num2;
}
function apply(num1,num2){
return sum.apply(this,num1,num2);
}
console.log(apply(1,2)); //3
以上為apply()和call()的基本用法,兩種方法的區(qū)別僅僅在于參數(shù)呈現(xiàn)形式的不同,所以具體使用哪一種根據(jù)個人的使用習(xí)慣即可。事實(shí)上,傳遞參數(shù)并非這兩個方法的用武之處,可以改變或者擴(kuò)展函數(shù)運(yùn)行的作用域才是這兩個方法真正強(qiáng)大的地方,下面用一個簡單的例子來說明。
let a = {
one:1,
two:2
}
let o = {
one:2,
two:3
}
function sum(){
return this.one+this.two;
}
sum.apply(a); //3
sum.apply(o); //5