ES5 this.method不是一个功能

时间:2017-09-29 17:07:49

标签: reactjs typescript ecmascript-5

我有一个针对ES5的打字稿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;
    }
  }
}

1 个答案:

答案 0 :(得分:2)

确保将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) => {
    // ...
  }
}