call、apply和bind的区别

call、apply和bind都是用于改变方法中this指向的。

var x = "window_x";
var obj = {
    x : "obj_x",
    fn : function(y){
        console.log(this.x + " ; " + y);
    }
}
obj.fn(1);  //obj_x ; 1
var fn = obj.fn;
fn(1);  //window_x ; 1
fn.call(obj,1);  //obj_x ; 1
fn.apply(obj,[1]);  //obj_x ; 1
fn.bind(obj,1);  //返回fn方法:f (y){console.log(this.x + " ; " + y);}
var bfn = fn.bind(obj);
bfn(1); //obj_x ; 1

执行结果:
在这里插入图片描述
call调用 将方法中的this指向call中第一个参数,当第一个参数为null、undefined时,默认指向window; call中第一个参数之后是要传递给方法的参数列表。

apply与call相似,不同之处在于传递给方法的参数形式不一致。apply传递给方法的参数是数组的形式。

call和apply在改变方法的this指向时,会同时执行方法;而bind不会执行方法,而是返回改变this指向后的新方法。

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值