深入解析react关于事件绑定this的四种方式

这篇文章主要介绍了详解react关于事件绑定this的四种方式,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。

在react组件中,每个方法的上下文都会指向该组件的实例,即自动绑定this为当前组件,而且react还会对这种引用进行缓存,以达到cpu和内存的最大化。在使用了es6 class或者纯函数时,这种自动绑定就不复存在了,我们需要手动实现this的绑定

React事件绑定类似于DOM事件绑定,区别如下:

  • 1.React事件的用驼峰法命名,DOM事件事件命名是小写
  • 2.通过jsx,传递一个函数作为event handler,而不是一个字符串。
  • 3.React事件不能通过返回false来阻止默认事件,需要显式调用preventDefault() 如下实例:
<a href="#" onclick="console.log('The link was clicked.'); return false">
Click me
</a>class ActionLink extends React.Component {
constructor(props) {
super(props);
}handleClick(e) {
e.preventDefault();
console.log('The link was clicked.');
}//欢迎加入前端全栈开发交流圈一起学习交流:864305860render() {
return (
<a href="#" onClick={this.handleClick.bind(this)}>Click Me...</a>
);
}}
复制代码

ps:React组件类的方法没有默认绑定this到组件实例,需要手动绑定。 以下是几种绑定的方法:

bind方法

直接绑定是bind(this)来绑定,但是这样带来的问题是每一次渲染是都会重新绑定一次bind;

class Home extends React.Component { constructor(props) {super(props);this.state = {};//欢迎加入前端全栈开发交流圈一起学习交流:864305860} del(){console.log('del')} render() {return (<div className="home"><span onClick={this.del.bind(this)}></span></div>);}
}
复制代码

构造函数内绑定

在构造函数 constructor 内绑定this,好处是仅需要绑定一次,避免每次渲染时都要重新绑定,函数在别处复用时也无需再次绑定

class Home extends React.Component { constructor(props) {super(props);this.state = { };//欢迎加入前端全栈开发交流圈一起学习交流:864305860this.del=this.del.bind(this)} del(){console.log('del')} render() {return (<div className="home"><span onClick={this.del}></span></div>);}
}
复制代码

::不能传参

如果不传参数使用双冒号也是可以

class Home extends React.Component { constructor(props) {super(props);this.state = { };//欢迎加入前端全栈开发交流圈一起学习交流:864305860} del(){console.log('del')} render() {return (<div className="home"><span onClick={::this.del}></span></div>);}
}
复制代码

箭头函数绑定

箭头函数不仅是函数的'语法糖',它还自动绑定了定义此函数作用域的this,因为我们不需要再对它们进行bind方法:

class Home extends React.Component {constructor(props) {super(props);this.state = { }; //欢迎加入前端全栈开发交流圈一起学习交流:864305860} del=()=>{console.log('del')}render() {return (<div className="home"><span onClick={this.del}></span></div>);}
}
复制代码

以上几种方法都可以实现this绑定,使用那种各自的习惯;希望对大家的学习有所帮助

结语

感谢您的观看,如有不足之处,欢迎批评指正。

本次给大家推荐一个免费的学习群,里面概括移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。 对web开发技术感兴趣的同学,欢迎加入Q群:864305860,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。 最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

转载于:https://juejin.im/post/5c150b36f265da61524d4979

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/276655.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Apache的认证、授权、访问控制

原文链接&#xff1a; http://man.chinaunix.net/newsoft/Apache2.2_chinese_manual/howto/auth.html Apache认证、授权、访问控制 认证(Authentication)是指任何识别用户身份的过程。授权(Authorization)是允许特定用户访问特定区域或信息的过程。 相关模块和指令 认证和授权…

黑马C++设计模式2

简单工厂模式 //一般来说&#xff0c;自己创建一个对象的方法是在自己写的业务函数中直接new一个对象出来//但是现实需求&#xff0c;我不想创建对象&#xff0c;我只想拿来用。&#xff08;创建类的步骤比较复杂&#xff09; //好处&#xff0c;1、客户端和具体实现类解耦。2…

[转]Struts 2.1发布

作者 Ian Roughley译者 崔康 发布于 2009年2月4日 上午8时13分 Struts2框架刚刚发布最新2.1版。该版本做了重大升级&#xff0c;包括重构更多代码到插件框架、通过增加convention插件减少XML配置和改进REST支持。 我采访了Musachy Barroso——该版本的一位开发人员&#xff0c…

dim private public static_PHP中const,static,public,private,protected的区别

const: 定义常量&#xff0c;一般定义后不可改变static: 静态&#xff0c;类名可以访问public: 表示全局&#xff0c;类内部外部子类都可以访问&#xff1b;private: 表示私有的&#xff0c;只有本类内部可以使用&#xff1b;protected: 表示受保护的&#xff0c;只有本类或子类…

C#图解教程 第六章 深入理解类

深入理解类 类成员 前两章阐述了9种类成员中的两种&#xff1a;字段和方法。本章将会介绍除事件(第14章)和运算符外的其他类成员&#xff0c;并讨论其特征。 成员修饰符的顺序 字段和方法的声明可以包括许多如public、private这样的修饰符。本章还会讨论许多其他修饰符。多个修…

Apache用户身份验证

原文链接&#xff1a;http://www.yylog.org/?p4830 Apache用户身份验证 在apache应用过程中&#xff0c;管理员经常需要对apache下的目录做一些限制&#xff0c;不希望所有用户都能访问该目录下的文件&#xff0c;只对指定用户访问&#xff0c;此时我们就要用到apache用户身…

携程elong相继牵手支付宝转“危”为“机”

新华网浙江频道1月16日电 自电子机票全面普及以来&#xff0c;航空公司机票直销的力度不断加强正给传统的机票代理甚至在线旅游平台带来了极大的生存压力。 而面对危机&#xff0c;在进一步丰富自身产品服务之外&#xff0c;大的在线旅行平台也终于找到对策。继eLong此前与支付…

c# 获取word表格中的内容_Java 获取、删除Word文本框中的表格

本文介绍如何来获取Word文本框中包含的表格&#xff0c;以及删除表格。程序测试环境包括&#xff1a;IDEAJDK 1.8.0Spire.Doc.jar注&#xff1a;jar导入&#xff0c;可通过创建Maven程序项目&#xff0c;并在pom.xml中配置Maven仓库路径&#xff0c;并指定Free Spire.Doc for J…

Array.prototype.reduce 的理解与实现

Array.prototype.reduce 是 JavaScript 中比较实用的一个函数&#xff0c;但是很多人都没有使用过它&#xff0c;因为 reduce 能做的事情其实 forEach 或者 map 函数也能做&#xff0c;而且比 reduce 好理解。但是 reduce 函数还是值得去了解的。 reduce 函数可以对一个数组进行…

PS抠图方法[photoshop中文教程]

PS抠图方法 一、魔术棒法——最直观的方法   适用范围&#xff1a;图像和背景色色差明显&#xff0c;背景色单一&#xff0c;图像边界清晰。   方法意图&#xff1a;通过删除背景色来获取图像。   方法缺陷&#xff1a;对散乱的毛发没有用。   使用方法&#xff1a…

我的核心技术都是从哪里学到的?如何提高成长的?分享给大家。

1997年&#xff0c;我在读黑龙江大学读大二时&#xff0c;我认识了一个内蒙古大学计算机专业毕业的一个高材生&#xff0c;那时我那朋友引导了我很多&#xff0c;他那时候在我们家那边开一个IT公司&#xff0c;他知道如何靠IT技术赚钱&#xff0c;如何靠程序等赚钱&#xff0c;…

python线性回归算法简介_Python实现的简单线性回归算法实例分析

本文实例讲述了Python实现的简单线性回归算法。分享给大家供大家参考&#xff0c;具体如下&#xff1a; 用python实现R的线性模型(lm)中一元线性回归的简单方法&#xff0c;使用R的women示例数据&#xff0c;R的运行结果&#xff1a; > summary(fit) Call: lm(formula weig…

Object/Relation Mapping 对象关系映射

对象-关系映射&#xff08;Object/Relation Mapping&#xff0c;简称ORM&#xff09;&#xff0c;是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法&#xff0c;关系数据库是企业级应用环境中永久存放数据的主流数据存储…

FastReport使用方法(C/S版)

前言 这两天群里一直有群友问一些关于FastReport的问题&#xff0c;结合他们的问题&#xff0c;在这里做一个整理&#xff0c;有不明白的可以加 FastReport 交流群 群 号&#xff1a;554714044 工具 VS2017 FastReport 开始 1.新建项目&#xff0c;添加三个按钮。预览、设计、…

如何设置Linux时区为东八区

当我们购买美国VPS或服务器的时候&#xff0c;默认情况下是美国时间。对于我们定时执行某些任务会带来麻烦&#xff0c;所以需要设置时区为东八区。登录SSH后&#xff0c;执行tzselect命令。我们这里选择亚洲5.这里选择china 9。一般选东八区&#xff08;北京&#xff0c;广东&…

python删除两个excel表中的相同元素_python筛选出两个文件中重复行的方法

查找A文件中&#xff0c;与B文件中内容不重复的内容#!usr/bin/python import sys import os字符串查找函数&#xff0c;使用二分查找法在列表中进行查询def binarySearch(value, lines): right len(lines) - 1 left 0 a value.strip() while left < right: middle int((…

求解:nhibernate2.0操作oralce提交事务时报错

代码如下: Configuration config new Configuration(); config.AddAssembly("TestCleanSnow"); ISessionFactory factory config.BuildSessionFactory(); ISession session f…

python画枫叶_python-文件的操作

一、异常 程序在运行的过程中&#xff0c;不可避免出现一些错误&#xff0c;这些错误成为异常 异常以后的代码都不会被执行 try 语句 代码块&#xff08;可能出现错误的语句&#xff09; except 异常类型 as 异常名: 代码块(出错以后执行的语句&#xff09; except 异常类型 as…

记2018年技术人一次短暂的创业

背景 2018年8月底&#xff0c;我全职加入了一家创业公司&#xff0c;具体做什么我暂时先不说吧&#xff0c;我是产品和技术负责人&#xff0c;自己出资了50w&#xff0c;大股东&#xff08;下面简称T)也就是ceo是早期阿里出身的中供销售&#xff0c;从2017年11月开始成立此公司…

如何在Apache环境下配置Rewrite规则

原文链接&#xff1a;http://faq.comsenz.com/viewnews-12 URL 静态化是一个利于搜索引擎的设置&#xff0c;通过 URL 静态化&#xff0c;达到原来是动态的 PHP 页面转换为静态化的 HTML 页面&#xff0c;当然&#xff0c;这里的静态化是一种假静态&#xff0c;目的只是提高搜…