我用es6改写react的组件,可是之后,组件的this指向居然变成了undefined
><,请大家帮忙看看,,谢谢
绑定事件时使用:
onChange={this.handleAuthorChange.bind(this)}
绑定事件时传递的只是一个函数,并没有 this
的指向,所以需要传递一个明确绑定好 this
的函数给 onXXX
进行处理。
之前React.createClass中事件是默认绑定到当前类中,但是使用es6语法的话,需要手动绑定。
handleAuthorChange = ()=>{
// do something
}
第二种方式就是通过以上说的。推荐第一种 ,毕竟少
constructor(){
this.handleCommentSubmit = this.handleCommentSubmit.bind(this);
}
4 回答1.7k 阅读
2 回答1.1k 阅读✓ 已解决
2 回答2.6k 阅读
1 回答973 阅读✓ 已解决
1 回答698 阅读✓ 已解决
2 回答862 阅读✓ 已解决
3 回答870 阅读
onChange的回调是在浏览器全局对象执行的,此时的this并不指向你定义的React组件部分。有两种方法:
使用function.prototype.bind()更改函数内部的this
使用es6的箭头函数,es6中的箭头函数this默认指向上一层级环境