JS 程序员应该知道的 bind 方法

发布于 2022-02-25 22:22:09 字数 1104 浏览 1133 评论 0

先别让我去 UC,先看看这段代码:

const objA = {
  num: 1,
};
const objB = {
  num: 2,
};

function fn() {
  console.log(this.num);
}

fn = fn.bind(objA);
fn = fn.bind(objB);

fn();

答案是啥?

竟然是...

1


@malcolmyu 同学的点拨下,猜测 bind 方法的实际返回一个内部使用 call 的匿名函数:

function bind(fn, context) {
  return function() {
    fn.call(context);
  };
}

下面通过实现 mybind 方法模拟 bind

Function.prototype.mybind = function(context) {
  return () => {
    this.call(context);
  }
}

验证下:

Function.prototype.mybind = function(context) {
  return () => {
    this.call(context);
  }
}

const objA = {
  num: 1,
};
const objB = {
  num: 2,
};

function fn() {
  console.log(this.num);
}

fn = fn.mybind(objA);
fn = fn.mybind(objB);

fn(); // 打印 1

哈哈,一毛一样。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

夢野间

文章 0 评论 0

doggiejohn

文章 0 评论 0

就此别过

文章 0 评论 0

初见终念

文章 0 评论 0

qq_rvKjBH

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文