-
监听函数on
没有经过特殊处理的话,这些 on* 的事件监听只能用在普通的 HTML 的标签上,而不能用在组件标签上。也就是说,<Header onClick={…} /> 这样的写法不会有什么效果的。这一点要注意,但是有办法可以做到这样的绑定,以后我们会提及。现在只要记住一点就可以了:这些 on* 的事件监听只能用在普通的 HTML 的标签上,而不能用在组件标签上。 -
事件处理函数this
试图打印事件函数中的this,它并没有返回当前实例。
class Title extends Component {
handleClickOnTitle (e) {
console.log(this) // => null or undefined
}
render () {
return (
<h1 onClick={this.handleClickOnTitle}>React 小书</h1>
)
}
}
真相是,react在调用handleClickOnTitle函数的时候,并不是采用调用对象方法的方式(this.handleClickOnTitle),而是采用函数调用的方式(handleClickOnTitle),因此事件调用函数并不能获取到this。如果要在事件调用函数中使用当前实例,就需要handleClickOnTitle.bind(this)
网友评论