私は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(これは)トリックでした。 – alexb