全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

React学习之事件绑定的几种方法对比

前言

本文主要给大家介绍了关于React事件绑定的几种方法对比的相关呢荣,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

React事件绑定

由于类的方法默认不会绑定this,因此在调用的时候如果忘记绑定,this的值将会是undefined。

通常如果不是直接调用,应该为方法绑定this。绑定方式有以下几种:

1. 在构造函数中使用bind绑定this

class Button extends React.Component {
constructor(props) {
 super(props);
 this.handleClick = this.handleClick.bind(this);
 }
 handleClick(){
 console.log('this is:', this);
 }
 render() {
 return (
  <button onClick={this.handleClick}>
  Click me
  </button>
 );
 }
}

2. 在调用的时候使用bind绑定this

class Button extends React.Component {
 handleClick(){
 console.log('this is:', this);
 }
 render() {
 return (
  <button onClick={this.handleClick.bind(this)}>
  Click me
  </button>
 );
 }
}

3. 在调用的时候使用箭头函数绑定this

class Button extends React.Component {
 handleClick(){
 console.log('this is:', this);
 }
 render() {
 return (
  <button onClick={()=>this.handleClick()}>
  Click me
  </button>
 );
 }
}

4. 使用属性初始化器语法绑定this(实验性)

class Button extends React.Component {
 handleClick=()=>{
 console.log('this is:', this);
 }
 render() {
 return (
  <button onClick={this.handleClick}>
  Click me
  </button>
 );
 }
}

比较

方式2和方式3都是在调用的时候再绑定this。

  • 优点:写法比较简单,当组件中没有state的时候就不需要添加类构造函数来绑定this
  • 缺点:每一次调用的时候都会生成一个新的方法实例,因此对性能有影响,并且当这个函数作为属性值传入低阶组件的时候,这些组件可能会进行额外的重新渲染,因为每一次都是新的方法实例作为的新的属性传递。

方式1在类构造函数中绑定this,调用的时候不需要再绑定

  • 优点:只会生成一个方法实例,并且绑定一次之后如果多次用到这个方法也不需要再绑定。
  • 缺点:即使不用到state,也需要添加类构造函数来绑定this,代码量多一点。。。

方式4:利用属性初始化语法,将方法初始化为箭头函数,因此在创建函数的时候就绑定了this。

  • 优点:创建方法就绑定this,不需要在类构造函数中绑定,调用的时候不需要再作绑定。结合了方式1、方式2、方式3的优点
  • 缺点:目前仍然是实验性语法,需要用babel转译

总结

方式1是官方推荐的绑定方式,也是性能最好的方式。方式2和方式3会有性能影响并且当方法作为属性传递给子组件的时候会引起重渲问题。方式4目前属于实验性语法,但是是最好的绑定方式,需要结合bable转译

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# react循环绑定事件  # react  # 绑定多个事件  # 事件绑定  # e  # React事件绑定的方式及区别详解  # React 事件绑定的实现及区别  # React组件创建与事件绑定的实现方法  # React事件绑定详解  # React事件绑定的方式详解  # React中事件绑定this指向三种方法的实现  # 详解react关于事件绑定this的四种方式  # React 事件绑定的最佳实践  # 绑定  # 不需  # 要再  # 都是  # 低阶  # 是在  # 会有  # 好了  # 最好的  # 将会  # 不需要  # 就不  # 说了  # 不多  # 要在  # 只会  # 给大家  # 几种  # 如果不是  # 仍然是 


相关文章: 如何快速选择适合个人网站的云服务器配置?  定制建站方案优化指南:企业官网开发与建站费用解析  如何通过宝塔面板实现本地网站访问?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  深圳网站制作的公司有哪些,dido官方网站?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  如何选择建站程序?包含哪些必备功能与类型?  如何挑选最适合建站的高性能VPS主机?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  独立制作一个网站多少钱,建立网站需要花多少钱?  招贴海报怎么做,什么是海报招贴?  大连 网站制作,大连天途有线官网?  南平网站制作公司,2025年南平市事业单位报名时间?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  如何快速生成可下载的建站源码工具?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  家庭建站与云服务器建站,如何选择更优?  活动邀请函制作网站有哪些,活动邀请函文案?  文字头像制作网站推荐软件,醒图能自动配文字吗?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  盐城做公司网站,江苏电子版退休证办理流程?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  建站之星如何快速解决建站难题?  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  怎么将XML数据可视化 D3.js加载XML  制作网站外包平台,自动化接单网站有哪些?  如何用5美元大硬盘VPS安全高效搭建个人网站?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何彻底删除建站之星生成的Banner?  如何正确下载安装西数主机建站助手?  建站之星CMS五站合一模板配置与SEO优化指南  内网网站制作软件,内网的网站如何发布到外网?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  建站主机如何选?性能与价格怎样平衡?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  建站之星2.7模板:企业网站建设与h5定制设计专题  盘锦网站制作公司,盘锦大洼有多少5G网站?  建站之星价格显示格式升级,你的预算足够吗?  山东网站制作公司有哪些,山东大源集团官网?  外贸公司网站制作哪家好,maersk船公司官网?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何在Windows虚拟主机上快速搭建网站?  广州美橙建站如何快速搭建多端合一网站?  如何快速启动建站代理加盟业务?  如何选择域名并搭建高效网站?  SQL查询语句优化的实用方法总结 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。