当前位置: 首页 > 面试题库 >

如何使用箭头函数(公共类字段)作为类方法?

饶铭
2023-03-14
问题内容

我是将ES6类与React结合使用的新手,以前我一直将我的方法绑定到当前对象(如第一个示例所示),但是ES6是否允许我将类函数永久地绑定到带有箭头的类实例上?(在作为回调函数传递时很有用。)当我尝试使用CoffeeScript尝试使用它们时,会出现错误:

class SomeClass extends React.Component {

  // Instead of this
  constructor(){
    this.handleInputChange = this.handleInputChange.bind(this)
  }

  // Can I somehow do this? Am i just getting the syntax wrong?
  handleInputChange (val) => {
    console.log('selectionMade: ', val);
  }

这样,如果我要传递SomeClass.handleInputChange给,例如setTimeout,它将仅限于类实例,而不是window对象。


问题答案:

您的语法略有不同,只是在属性名称后缺少等号。

class SomeClass extends React.Component {
  handleInputChange = (val) => {
    console.log('selectionMade: ', val);
  }
}

这是一项实验功能。您将需要在Babel中启用实验功能才能进行编译。这是一个启用实验的演示。

要在babel中使用实验性功能,您可以从此处安装相关的插件。对于此特定功能,您需要transform- class-properties插件:

{
  "plugins": [
    "transform-class-properties"
  ]
}

您可以在此处阅读有关“类字段和静态属性”提案的更多信息



 类似资料:
  • 问题内容: 当我尝试整理Es6类时,ESLint引发错误。我缺少在eslint中启用胖箭头类方法的配置参数吗? 范例类别: .eslint 问题答案: 如果要使用实验性功能(例如箭头作为类方法),则需要用作解析器。默认解析器(Espree)不支持实验性功能。

  • 问题内容: class App extends Component { constructor(props) { … } 在类中声明的两种函数 (onChange和onSubmit) 之间有什么区别?如果我将其声明为ES6类方法,但在 const url中 引用this.sate时出现错误,但是将其更改为arrow函数可以解决此问题。 我想知道两种情况下如何正确处理“ this” 另外,我该如何做

  • 不鼓励将箭头函数(“lambdas”)传递给 Mocha。Lambdas词法绑定 this,无法访问 Mocha 上下文。例如,以下代码将失败: describe('my suite', () => { it('my test', () => { // should set the timeout of this test to 1000 ms; instead will fail thi

  • ES6标准新增了一种新的函数:Arrow Function(箭头函数)。 为什么叫Arrow Function?因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 在继续学习箭头函数之前,请测试你的浏览器是否支持ES6的Arrow Function: 'use strict'; ---- var f

  • 本文向大家介绍如何用箭头函数获取arguments相关面试题,主要包含被问及如何用箭头函数获取arguments时的应答技巧和注意事项,需要的朋友参考一下 参考回答: 可用…rest参数获取  

  • 当使用面向对象语言(如C#或Java)编程时,是否有一种好的情况,在类中声明一个公共字段实际上是有效的(我自己总是使用一个属性来使类的用户不依赖数据并支持数据保护)?否则,例如,C#允许你这样做,这感觉很奇怪。