bind()在JavaScript中有什么用途?

推荐答案

Bind创建一个新函数,该函数将强制函数中的this作为传递给bind()的参数.

下面的示例演示了如何使用bind传递具有正确this的成员方法:

var myButton = {
  content: 'OK',
  click() {
    console.log(this.content + ' clicked');
  }
};

myButton.click();

var looseClick = myButton.click;
looseClick(); // not bound, 'this' is not myButton - it is the globalThis

var boundClick = myButton.click.bind(myButton);
boundClick(); // bound, 'this' is myButton

打印出:

OK clicked
undefined clicked
OK clicked

您还可以在第一个(this)参数之后添加额外的参数,bind会将这些值传递给原始函数.稍后传递给绑定函数的任何附加参数都将在绑定参数之后传入:

// Example showing binding some parameters
var sum = function(a, b) {
  return a + b;
};

var add5 = sum.bind(null, 5);
console.log(add5(10));

打印出:

15

查看JavaScript Function bind了解更多信息和互动示例.

更新:ECMAScript 2015增加了对=>个函数的支持.=>函数更紧凑,并且不会从定义范围更改this指针,因此您可能不需要经常使用bind().例如,如果您希望第一个示例中的Button上的函数将click回调连接到DOM事件,那么以下都是有效的方法:

var myButton = {
  ... // As above
  hookEvent(element) {
    // Use bind() to ensure 'this' is the 'this' inside click()
    element.addEventListener('click', this.click.bind(this));
  }
};

或者:

var myButton = {
  ... // As above
  hookEvent(element) {
    // Use a new variable for 'this' since 'this' inside the function
    // will not be the 'this' inside hookEvent()
    var me = this;
    element.addEventListener('click', function() { me.click() });
  }
};    

或者:

var myButton = {
  ... // As above
  hookEvent(element) {
    // => functions do not change 'this', so you can use it directly
    element.addEventListener('click', () => this.click());
  }
};

Javascript相关问答推荐

如何在不分配整个数组的情况下修改包含数组的行为主体?

我试图实现用户验证的reduxstore 和操作中出了什么问题?

yarn安装一个本地npm包,以便本地包使用main项目的node_modules(ckeditor-duplicated-modules错误)

如何解决chrome—extension代码中的错误,它会实时覆盖google—meet的面部图像?'

Snowflake JavaScript存储过程返回成功,尽管预期失败

仅针对RTK查询中的未经授权的错误取消maxRetries

如何从隐藏/显示中删除其中一个点击?

还原器未正确更新状态

Websocket错误—有一个或多个保留位开启:reserved1 = 1,reserved2 = 0,reserved3 = 0

如何将多维数组插入到另一个多维数组中?

如何修复我的数据表,以使stateSave正常工作?

NG/Express API路由处理程序停止工作

如何在.NET Core中将chtml文件链接到Java脚本文件?

为什么在函数中添加粒子的速率大于删除粒子的速率?

打字脚本中方括号符号属性访问和拾取实用程序的区别

使每个<;li>;元素的 colored颜色 与随机生成的 colored颜色 列表不同(不重复

在没有任何悬停或其他触发的情况下连续交换图像

Chrome上的印度时区名S有问题吗?

将字体样式应用于material -UI条形图图例

如何使用useparams从react路由中提取id