React事件监听

  1. 监听函数on
    没有经过特殊处理的话,这些 on* 的事件监听只能用在普通的 HTML 的标签上,而不能用在组件标签上。也就是说,

    这样的写法不会有什么效果的。这一点要注意,但是有办法可以做到这样的绑定,以后我们会提及。现在只要记住一点就可以了:这些 on* 的事件监听只能用在普通的 HTML 的标签上,而不能用在组件标签上。

  2. 事件处理函数this
    试图打印事件函数中的this,它并没有返回当前实例。

class Title extends Component {
  handleClickOnTitle (e) {
    console.log(this) // => null or undefined
  }

  render () {
    return (
      

React 小书

) } }

真相是,react在调用handleClickOnTitle函数的时候,并不是采用调用对象方法的方式(this.handleClickOnTitle),而是采用函数调用的方式(handleClickOnTitle),因此事件调用函数并不能获取到this。如果要在事件调用函数中使用当前实例,就需要handleClickOnTitle.bind(this)

你可能感兴趣的:(React事件监听)