美文网首页
事件监听

事件监听

作者: SamDing | 来源:发表于2017-07-24 18:36 被阅读32次

事件监听


在React.js里面监听是一件很容易的事情,只需要在需要监听事件的元素加上类似onClick的属性,例如:

class Header extends Component {
  handleClickOnTitle () {
    console.log('Click on title.')
  }

  render () {
    return (
      <h1 onClick={this.handleClickOnTitle}>事件监听</h1>
    )
  }
}

h1标签加上了onClick属性,onClick紧更着一个表达式,这个表达式返回一个Header这个组件的一个实例方法。当用户点击h1标签的时候,控制台上就会输出Click on title,类似AngularJs里面的ngClick

在 React.js 不需要手动调用浏览器原生的 addEventListener 进行事件监听。React.js 帮我们封装好了一系列的 on* 的属性,当你需要为某个元素监听某个事件的时候,只需要简单地给它加上 on* 就可以了。而且你不需要考虑不同浏览器兼容性的问题,React.js 都帮我们封装好这些细节了。

但是,事件监听只能加在普通的HTML标签上,而不能加在自定义的Component上,例如<Header onClick={...}>,这样是没有效果的。但是有办法可以做到这样的绑定,目前我还不知道。。。

event对象


事件监听函数会被传入一个event对象,这个对象和浏览器中监听事件传递的对象基本是一致的,不过React.js将原声的event对象封装了一下,对外提供统一的API和属性,我们同样不用去关心浏览器兼容问题。尝试以下代码查看效果:

class Header extends Component {
  handleClickOnTitle (e) {
    console.log(e.target.innerHTML)
  }

  render () {
    return (
      <h1 onClick={this.handleClickOnTitle}>事件监听</h1>
    )
  }
}

点击后,控制台会输出‘事件监听’。

事件中的this


一般this表示对象本身,如果你尝试在上述代码中的方法handleClickOnTitle里将this打印出来,会发现控制台输出的是undefine。

class Header extends Component {
  handleClickOnTitle (e) {
    console.log(this)
  }

  render () {
    return (
      <h1 onClick={this.handleClickOnTitle}>事件监听</h1>
    )
  }
}

这是因为React.js在调用方法时,不是通过对象方法的方式调用的(this.handleClickOnTitle),而是直接通过调用函数(handleClickOnTitle)来执行的。所以事件监听函数内并不能通过this来获取实例。

如果想在事件函数中使用当前的实例,就需要手动将实例方法bind到当前实例上,再传入给React.js。

class Header extends Component {
  handleClickOnTitle (e) {
    console.log(this)
  }

  render () {
    return (
      <h1 onClick={this.handleClickOnTitle.bind(this)}>事件监听</h1>
    )
  }
}

这样实例方法就绑定了当前实例this,便可以在实例方法中使用当前实例的数据或方法。

也可以在bind的时候给事件监听传入参数:

class Header extends Component {
  handleClickOnTitle (word, e) {
    console.log(this, word)
  }

  render () {
    return (
      <h1 onClick={this.handleClickOnTitle.bind(this, 'Hello')}>事件监听</h1>
    )
  }
}

总结


  • 为 React 的组件添加事件监听是很简单的事情,你只需要使用 React.js 提供了一系列的 on* 方法即可。

  • React.js 会给每个事件监听传入一个 event 对象,这个对象提供的功能和浏览器提供的功能一致,而且它是兼容所有浏览器的。

  • React.js 的事件监听方法需要手动 bind 到当前实例,这种模式在 React.js 中非常常用。

相关文章

  • Android之常用Listener监听器

    常用Listener监听器 ListView事件监听: EditText事件监听: RadioGroup事件监听:...

  • 2021-09-22 GUI(事件监听机制)

    事件监听机制组成事件源(组件)事件(Event)监听器(Listener)事件处理(引发事件后处理方式) 事件监听...

  • 监听事件之Target-Action、协议代理

    监听事件:事件指点击,触摸这样的手势所引发的消息,监听事件即监听这类消息。监听事件的目的是处理这类消息。 监听产生...

  • unity 委托事件

    定义委托及事件 实现事件监听+=(事件取消监听为-=)

  • 37 高级:MVC

    课堂笔记 如何监听 的提交事件 为什么不监听click 事件?因为仅监听'click'事件时,便无法监听用户使用回...

  • spark 中的事件总线 ListenerBus

    事件监听模式一般需要定义3种组件:事件对象,事件源,事件监听器。在spark里面事件监听由ListenerBus组...

  • 下单流程解耦新方案-你知道Spring事件监听机制吗

    一、Spring事件监听介绍 Spring对事件监听是通过事件类型、事件类型监听和事件发布器3个部分来完成的 上面...

  • Java事件监听器的工作步骤介绍

    在程序开发中,经常需要对某些事件进行监听,如监听鼠标点击事件、监听键盘按下事件等,此时就需要使用事件监听器,事件监...

  • Linstener:监听器

    事件监听机制事件:一个事情事件源:时间发生的地方监听器:一段对象注册监听:将事件,事件源,监听器绑定在一起,当事件...

  • Web笔记-Listener

    事件源、事件、监听器 事件源:发生事件的对象 事件:事件封装了事件源,方便监听器的某个方法获取到事件源对象 监听器...

网友评论

      本文标题:事件监听

      本文链接:https://www.haomeiwen.com/subject/ssabkxtx.html