JavaScript双冒号(绑定运算符)

如您所知,有一个.bind()功能快捷方式的建议,因此您可以编写:

::this.handleStuff

它将在es5中像这样工作:

this.handleStuff.bind(this)

我的问题是:是否可以通过这种方式传递参数?

我的意思是用上述快捷方式编写此代码的方法:

this.handleStuff.bind(this, 'stuff')

这是React中很常见的模式,因此最好将其缩短一点。

回答:

否。bind运算符(规范建议)有两种形式:

  • 方法提取

    ::obj.method     ≡ obj.method.bind(obj)

  • “虚拟方法”调用

    obj::function    ≡ function.bind(obj)

    obj::function(…) ≡ function.call(obj, …)

它们都不具有部分应用的功能。对于您想要的,应该使用箭头功能:

(...args) => this.handleStuff('stuff', ...args) ≡ this.handleStuff.bind(this, 'stuff')

以上是 JavaScript双冒号(绑定运算符) 的全部内容, 来源链接: utcz.com/qa/432899.html

回到顶部