【问题标题】:ES5 this.method is not a functionES5 this.method 不是函数
【发布时间】:2018-03-11 15:37:35
【问题描述】:

我有一个针对 ES5 的 typescript 2 类。当我运行它时,我在控制台的主题行中得到错误。 switch 语句工作正常,但 increment() 和 decrement() 方法不执行。

class MyClass extends React.Component{
  ...
  increment() {
    console.log('increment()')
    ...
  }
  decrement() {
    console.log('decrement()')
    ...
  }

  buttonClick(btn) {
    console.log(btn)
    switch (btn) {
        case "prev":
            console.log('switch prev')
            this.decrement();
            //this.decrement;
            break;
        default:
            console.log('switch next')
            this.increment();
            //this.increment; eliminates err but method still doesnt execute
            break;
    }
  }
}

【问题讨论】:

  • 如果这是反应,请尝试将 .bind(this) 放在调用 buttonClick 的 jsx 模板中。例如onClick={this.buttonClick.bind(this)}
  • 你没有告诉我们你在哪里以及如何打电话给buttonClick,这很重要
  • Thx @gautsch this.buttonClick.bind(this) 成功了。

标签: reactjs typescript ecmascript-5


【解决方案1】:

确保将this 绑定到您的函数,这样this 的值将是您在调用函数时所期望的值:

class MyClass extends React.Component{
  constructor() {
    super()
    this.increment = this.increment.bind(this)
    this.decrement = this.decrement.bind(this)
    this.buttonClick = this.buttonClick.bind(this)
  }
  increment() {
    console.log('increment()')
  }
  decrement() {
    console.log('decrement()')
  }
  buttonClick(btn) {
    // ...
  }
}

如果您愿意,也可以使用属性初始化的箭头函数:

class MyClass extends React.Component{
  increment = () => {
    console.log('increment()')
  }
  decrement = () => {
    console.log('decrement()')
  }
  buttonClick = (btn) => {
    // ...
  }
}

【讨论】:

  • 我可能错了,但我认为this.buttonClick 需要绑定而不是decrementincrement
  • @bennygenel 你能详细解释(或提供链接)为什么我需要绑定 buttonClick 但不减量等吗?我今天就遇到了这种情况,它起作用了,但我不知道为什么。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-03-28
  • 2017-07-03
  • 1970-01-01
  • 2019-11-01
相关资源
最近更新 更多