this和手写apply、call、bind函数

一、this的指向

this的指向是在函数被调用时确定的,它指向调用该函数的对象。

在不同的情况下,this的指向会有所不同,常见的情况包括:

  1. 全局环境下,this指向全局对象(在浏览器中指向window对象)。
  2. 函数中的this,取决于函数的调用方式。如果函数被作为对象的方法调用,this指向调用该方法的对象;如果函数被直接调用,this指向全局对象。
  3. 使用构造函数创建对象时,this指向新创建的实例对象。
  4. 使用callapplybind方法可以手动指定函数中this的指向。

二、手写apply、call、bind函数

1. 手写apply函数

apply方法的作用是调用一个具有指定this值的函数,并以一个指定的参数数组的形式传递参数。

Function.prototype.myApply = function (context, args) {
  context = context || window;
  const fn = Symbol();
  context[fn] = this;
  const result = context[fn](...args);
  delete context[fn];
  return result;
};

// 测试
function greet(name) {
  return `Hello, ${name}!`;
}

const obj = { name: 'Alice' };
console.log(greet.myApply(obj, ['Bob'])); // 输出:Hello, Bob!

2. 手写call函数

call方法的作用与apply类似,区别在于参数的传递方式不同。

Function.prototype.myCall = function (context, ...args) {
  context = context || window;
  const fn = Symbol();
  context[fn] = this;
  const result = context[fn](...args);
  delete context[fn];
  return result;
};

// 测试
function greet(name) {
  return `Hello, ${name}!`;
}

const obj = { name: 'Alice' };
console.log(greet.myCall(obj, 'Bob')); // 输出:Hello, Bob!

3. 手写bind函数

bind方法创建一个新的函数,在调用时将其this值设置为提供的值。

Function.prototype.myBind = function (context, ...args) {
  const self = this;
  return function (...newArgs) {
    return self.apply(context, args.concat(newArgs));
  };
};

// 测试
function greet(name) {
  return `Hello, ${name}!`;
}

const obj = { name: 'Alice' };
const boundFn = greet.myBind(obj, 'Bob');
console.log(boundFn()); // 输出:Hello, Bob!

三、applycallbind的相同与不同之处

  1. 相同点:

    • applycallbind都是用来改变函数执行时的上下文(this指向)。
    • 它们都是Function对象的原型方法,可以在函数对象上直接调用。
  2. 不同点:

    • applycall的作用是立即执行函数,只是传递参数的方式不同,apply以数组形式传递参数,而call是一个一个传递参数。
    • bind方法不会立即执行函数,而是返回一个新的函数,可以在后续调用时执行。
    • bind方法可以预先绑定函数执行时的参数,而applycall只能在调用时传递参数。
  • 12
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值