深入理解 JavaScript 中 call()与 apply()方法

1. 作用

在特定的作用域调用函数,等于改变函数体内 this 的指向,以扩充函数赖以运行的作用域。

window.color="red";
var o={color:"blue"};
function getColor(){
    console.log(this.color);
}
getColor.call(this);   //red
getColor.call(window); //red
getColor.call(o);      //blue

2. 区别

call:第一个参数是运行函数的作用域,其余参数都直接传递给函数,即传递给函数的参数必须逐个列举出来。

apply:第一个参数是运行函数的作用域 ,另一个参数是参数数组,可以是 Array 实例或 arguments 对象。

给出两段代码帮助理解:

function add(c, d){ 
    return this.a + this.b + c + d; 
} 
var o = {a:1, b:3}; 
add.call(o, 5, 7);      // 1 + 3 + 5 + 7 = 16 
add.apply(o, [10, 20]); // 1 + 3 + 10 + 20 = 34
function sum(num1,num2){
    return num1+num2;
}

function callSum(num1,num2){
    return sum.call(this,num1,num2);
}

function callSum(num1,num2){
    return sum.apply(this,arguments);
}

function callSum(num1,num2){
    return sum.apply(this,[num1,num2]);
}

3. 二者与 bind 的区别

bind 传参的方式和 call 相同;
call 与 apply 会立即执行函数,bind 不会

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值