react点击事件的几种写法是什么
时间:2022-04-24 [网络编程]作者:fabuyuan 浏览:8 次
写法:1、用“onClick={this.handleClick}”;2、用“onClick={this.handleClick.bind(this)}”;3、用“{(params)=>this.handleClick(params)}”。
本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。
react点击事件的几种写法是什么
开门见山,先直接给出为一个button添加一个事件的正确写法:
为一个button添加一个onclick事件的正确写法
- 不传参数
// handleClick用 <箭头函数> 定义
onClick = { this.handleClick }
// handleClick用箭头函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick }></Button>
handleClick这么定义:
handleClick = () => { // do something here};
或
// handleClick用 (普通函数) 定义
onClick = { this.handleClick.bind(this) }
// handleClick用普通函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick.bind(this) }></Button>
handleClick这么定义:
handleClick () { // do something here }
- 传参数
// handleClick用 <箭头函数>/(普通函数) 定义都可以
onClick = { (params) => this.handleClick(params) }
// handleClick可以是箭头函数,也可以是普通函数<Button onClick = { (params) => this.handleClick(params) }></Button>
接下来分析一下为什么这样写是正确的:
this的指向分析
理解这个问题,带着下面这几句话去理解:
箭头函数,没有自己的this,所以它的this是 : 定义时上下文 的this
普通函数,有自己的this,所以它的this是:执行时上下文的this
先来看第一种写法:
1. onClick = { this.handleClick } + 箭头函数
下面给出的代码为:为一个按钮添加onclick事件(一个完整的jsx)
// examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component { // 2. 定义handleClick事件 handleClick = () => { console.log(this); //3. this指向examplePage } render() { return ( <p> // 1. 为onClick绑定 handleClick事件处理函数 <Button onClick = { this.handleClick }>click me</Button> </p> ) }}export default examplePage;
点击按钮,打印出指向examplePage的this:
this: examplePage {props: Object, context: {}, refs: {}, updater: Object, state: {}, …}
分析:
- 当点击Button,调用handleClick事件处理函数,
- 因为handleClick是一个箭头函数,因此 this是 定义时上下文的this ,
- handleClick在class examplePage 中定义的 ,
- 所以this指向examplePage
- 再看如果把箭头函数改为普通函数的情况:
2. onClick = { this.handleClick.bind(this) } + 普通函数
先来看,如果不用bind(this),console.log(this)会输出什么:
// examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component { // 2. !将箭头函数改为普通函数 handleClick () { console.log(this); // 3. this 为 undefined } render() { return ( <p> // 1. 为onClick绑定 handleClick事件处理函数 <Button onClick = { this.handleClick }>click me</Button> </p> ) }}export default examplePage;
点击按钮,打印出this:
this: undefined
分析:
- 当点击Button,调用handleClick事件处理函数,
- 因为handleClick是一个普通函数,因此 this是 执行时上下文的this ,
- handleClick在页面中点击Button时执行的 ,上下文环境是html的那个页面
- 所以this是undefined,并不指向examplePage
注:在严格版中,默认的this不再是window,而是undefined
Module code is always strict mode code.
All parts of a ClassDeclaration or ClassExpression are strict mode code.
因此需要用bind来改变this指向,即:
render() { return ( <p> // 用bind改变this指向 <Button onClick = { this.handleClick.bind(this) }>click me</Button> </p> )}
分析:
- 当点击Button,调用handleClick事件处理函数,
- 通过bind()函数,将render函数的this(指向class examplePage),当作一个变量传入handleClick
- 本来handleClick是一个普通函数, this是 执行时上下文的this(即 undefined),但因为bind(this)传入- - 了指向examplePage的this
- 所以此时,this是指向examplePage,解决了this为undefined的问题
理解了上面两个,最后一个就很好理解了:
3. onClick = { (params) => this.handleClick(params) } + 普通函数/箭头函数都可
render() { return ( <p> // 通过箭头函数传参 <Button onClick = { (params) => this.handleClick(params) }></Button> </p> )}
分析:
- 通过箭头函数传参数,相当于onClick绑定了一个箭头函数
- 点击Button时,调用(params) => this.handleClick(params)这个箭头函数,因此 this是 定义时上下文的this ,
- handleClick在class examplePage 中定义的 ,
- 所以this指向examplePage
- 按这种思路,只要把onClick的响应事件用箭头函数来写,调用的时候,this指向的都是该组件class,就不会有问题
那么,不传参的时候,就这么写:
<Button onClick = { () => this.handleClick() }></Button>
但这是不可行的,因为react会直接解析()=> this.handleClick(), handleClick会被调用,相当于onClick = “调用handleClick的结果”
所以,不传参数的时候只能这么写:
<Button onClick = { this.handleClick }></Button>
总结
开头的三个问题可以得到回答
- 什么情况下需要bind(this)?
答: onClick传入的事件处理函数是普通函数的时候,需要bind(this)来改变指向 - 为什么要用bind(this)?
答:如果不用bind(this), this会指向undefined - 可以不用bind(this)吗?
答:用箭头函数 (用箭头函数定义事件处理函数)
//定义handleClick事件 handleClick = () => { // do something here }; //为onClick绑定handleClick事件处理函数 <Button onClick = {this.handleClick}></Button> // 不传参 <Button onClick = {(param) => this.handleClick(param) }></Button> // 传参
推荐学习:《react视频教程》
以上就是react点击事件的几种写法是什么的详细内容,更多请关注站长家园其它相关文章!
本文标签: React
转载请注明来源:react点击事件的几种写法是什么
本文永久链接地址:https://www.adminjie.com/post/11536.html
免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!
版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。
更多精彩内容
- VUE中V-IF条件判断改变元素的样式操作
- Discuz如何解决安装时报错run_sql_error
- 低版本VS项目在VS2019无法正常编译的问题
- PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
- Oracle数据库的实例/表空间/用户/表之间关系简单讲解
- RSA2是啥?PHP-RSA2签名验证怎么实现?
- 华为dubal20是什么型号
- html5的标题标记一共有几个等级
- ana an00华为是什么型号
- 电脑显示信号线无连接是什么意思
- app是什么应用程序的简称
- html5中onclick是什么意思
- vivov1818a是什么手机型号
- 超链接的作用是什么
- 小程序大小超限除了分包还能怎么做?如何避免和解决大小限制?

- 最新文章
-
-
linux中什么是静态路由
在linux中,静态路由是路由项由手动设置的一种路由方式;即使网络状态已经改变或重新被组态,静态路由也是固定不变的,静态路由由网络管理员逐项加入路由表,可用“r...
-
php数组相加会合并重复值么
php数组相加不会合并重复值。php中可使用“+”运算符将一个或多个数组相加起来,会合并这些数组返回一个新数组,语法“数组1+数组2+..”,后面数组的元素会追...
-
php怎么去掉数组前一个元素
方法:1、用“array_values($arr)”将数组转为索引数组;2、用“array_search(值,数组)”从索引数组中搜索值,并返回对应索引;2、用...
-
浅析nodejs项目中的package.json的常见配置属性
本篇文章带大家了解一下node项目中的package.json配置文件,聊聊package.json中一些常见配置属性、环境相关属性、依赖相关属性和三方属性,希...
-
聊聊如何利用uniapp开发一个贪吃蛇小游戏!
如何利用uniapp开发一个贪吃蛇小游戏?下面本篇文章就手把手带大家在uniapp中实现贪吃蛇小游戏,希望对大家有所帮助!第一次玩贪吃蛇还隐约记得是?️后父亲给...
-
- 热门文章
-
-
VUE中V-IF条件判断改变元素的样式操作
这篇文章主要介绍了VUE中V-IF条件判断改变元素的样式操作,具有很好的参考价值,希望对大家有所帮助。一起跟随想过来看看吧...
-
Discuz如何解决安装时报错run_sql_error
问题环境VMware虚拟机Centos7.3PHP7.0MySQL8.0NGINX1.14Discuz3.4问题还原本地环境为PHP5.6+MySQL5.6在安...
-
低版本VS项目在VS2019无法正常编译的问题
低版本VS项目在VS2019无法正常编译的问题这里指的编译并不准确,只是为了方便说明。后有(未安装),201?...
-
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
实现原理使用redis链表来做,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,推荐使用。实现步骤第一步,先将商品库存入队列/**.trigge...
-
Oracle数据库的实例/表空间/用户/表之间关系简单讲解
完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例。Oracle是一种数据库管理系统,是一种关系型的数据库管理系统。我们用这些高级权限账号...
-