0
ES5를 대상으로하는 typescript 2 클래스가 있습니다. 콘솔을 실행할 때 제목 줄에 오류가 나타납니다. switch 문은 제대로 작동하지만 increment() 및 decrement() 메서드는 실행되지 않습니다.ES5 this.method가 함수가 아닙니다.
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;
}
}
}
이것이 반응하는 경우 buttonClick을 호출하는 jsx 템플릿에'.bind (this)'를 넣어보십시오. 예 : 'onClick = {this.buttonClick.bind (this)}' – gautsch
중요한 것은'buttonClick'을 호출하는 곳과 방법을 알려주지 않았습니다. – Bergi
Thx @gautsch this.buttonClick.bind (this)이 트릭을했습니다. – alexb