ES5 this.method 不是函数
ES5 this.method is not a function
我有一个针对 ES5 的打字稿 2 class。当我 运行 时,我在控制台的主题行中收到错误。 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;
}
}
}
确保将 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) => {
// ...
}
}
我有一个针对 ES5 的打字稿 2 class。当我 运行 时,我在控制台的主题行中收到错误。 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;
}
}
}
确保将 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) => {
// ...
}
}