call、apply、bind 的用法与区别

本文探讨了JavaScript中this的基本规则,即调用者决定this的指向。同时,介绍了call、apply和bind这三种方法用于改变函数调用时的上下文(this)。call和apply的区别在于传递参数的方式,前者逐个传递,后者接受一个参数数组。bind则主要用于绑定this并可预设参数,但不会立即执行函数。
摘要由CSDN通过智能技术生成

1、老生常谈的问题,this 指向,我们经常听到这句话:谁调用 this 就指向谁,如:

const obj1 = {
  name: 'obj1',
  getName() {
    console.log(this.name);
  },
};

const obj2 = {
  name: 'obj2',
  getName() {
    console.log(this.name);
  },
};

obj1.getName(); // obj1
obj2.getName(); // obj2

2、但是我们常常需要修改 this 指向,这个时候 call、apply、bind 的第一个参数都是用来改变 this 指向的,如:

// 把this指向obj2
obj1.getName.call(obj2); // obj2
obj1.getName.apply(obj2); // obj2
obj1.getName.bind(obj2)(); // obj2

三者区别:call 和 apply 会自动执行函数,bind 不会自动执行,需要手动加小括号执行

3、关于 call、apply、bind 的传参区别:call 是挨个挨个传参,apply 是以数组形式传参,bind 可以挨个挨个传,也可以放在数组里挨个挨个传,如:

const obj1 = {
  name: 'obj1',
  getName(fm = 'A', to = 'B') {
    console.log(this.name + ',来自' + fm + '去往' + to);
  },
};

const obj2 = {
  name: 'obj2',
  getName() {
    console.log(this.name);
  },
};

obj1.getName.call(obj2, '汕头', '广州'); // obj2,来自汕头去往广州
obj1.getName.apply(obj2, ['汕头', '广州']); // obj2,来自汕头去往广州
obj1.getName.bind(obj2, '汕头', '广州')(); // obj2,来自汕头去往广州
obj1.getName.bind(obj2, ['汕头'], ['广州'])(); // obj2,来自汕头去往广州
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值