React事件及绑定方式

因为React里我们操作的都是虚拟DOM,所有在JSX语法结构里绑定的事件并不是真正的DOM事件,我们称之为"React控制事件";

语法:

on+事件名 (事件名首字母大写,且使用驼峰命名法)

例如:onClick,onMouseover

绑定事件方式一(不推荐使用)

特点:

1.调用的方法中不能访问this,因为this未被绑定(undefined);

2.不能传参;

3.可以获取事件触发时产生的事件对象;

事件绑定的方式二(常用)

使用bind方法绑定,第一个参数是绑定的实例对象this(组件实例对象),从参数2以后,是事件触发时,传递的参数(实参);

on+事件名={this.方法名.bind(this)}

有参数时

特点:

1.调用的方法中能够获取this对象(组件实例对象);

2.能够直接传参;

3.可以获取事件触发时产生的事件对象;

事件绑定的方式三:

使用箭头函数

on+事件名={()=>{ this.方法名(参数1,参数2)} }

有参数时

特点:

1.调用的方法中能够获取this对象(组件实例对象);

2.能够直接传参;

3.不可以直接获取事件触发时产生的事件对象;

事件绑定的方式四:

在constructor方法中,修改this的指向

this.方法名 = this.方法名.bind(this);

 

特点:

1.调用的方法中能够获取this对象(组件实例对象);

2.不能直接传参;

3.可以获取事件触发时产生的事件对象;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值