react点击事件的写法有哪些


这篇文章主要讲解了“react点击事件的写法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react点击事件的写法有哪些”吧! 写法:1、用“onClick={this.handleClick}”;2、用“onClick={this.handleClick.bind(this)}”;3、用“{(params)=>this.handleClick(params)}”。本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。开门见山,先直接给出为一个button添加一个事件的正确写法:
为一个button添加一个onclick事件的正确写法不传参数// handleClick用 定义
onClick = { this.handleClick }handleClick这么定义:或// handleClick用 (普通函数) 定义
onClick = { this.handleClick.bind(this) }handleClick这么定义:传参数// handleClick用 /(普通函数) 定义都可以
onClick = { (params) => this.handleClick(params) }接下来分析一下为什么这样写是正确的:理解这个问题,带着下面这几句话去理解:箭头函数,没有自己的this,所以它的this是 : 定义时上下文 的this
普通函数,有自己的this,所以它的this是:执行时上下文的this先来看第一种写法:下面给出的代码为:为一个按钮添加onclick事件(一个完整的jsx)
//1.为onClick绑定handleClick事件处理函数

点击按钮,打印出指向examplePage的this:this: examplePage {props: Object, context: {}, refs: {}, updater: Object, state: {}, …}分析:当点击Button,调用handleClick事件处理函数,因为handleClick是一个箭头函数,因此 this是 定义时上下文的this ,handleClick在class examplePage 中定义的 ,所以this指向examplePage再看如果把箭头函数改为普通函数的情况:先来看,如果不用bind(this),console.log(this)会输出什么:
//1.为onClick绑定handleClick事件处理函数

点击按钮,打印出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指向,即:
//用bind改变this指向

分析:当点击Button,调用handleClick事件处理函数,通过bind()函数,将render函数的this(指向class examplePage),当作一个变量传入handleClick本来handleClick是一个普通函数, this是 执行时上下文的this(即 undefined),但因为bind(this)传入- – 了指向examplePage的this所以此时,this是指向examplePage,解决了this为undefined的问题理解了上面两个,最后一个就很好理解了:
//通过箭头函数传参

分析:通过箭头函数传参数,相当于onClick绑定了一个箭头函数点击Button时,调用(params) => this.handleClick(params)这个箭头函数,因此 this是 定义时上下文的this ,handleClick在class examplePage 中定义的 ,所以this指向examplePage按这种思路,只要把onClick的响应事件用箭头函数来写,调用的时候,this指向的都是该组件class,就不会有问题那么,不传参的时候,就这么写:但这是不可行的,因为react会直接解析()=> 免费云主机域名this.handleClick(), handleClick会被调用,相当于onClick = “调用handleClick的结果”所以,不传参数的时候只能这么写:总结
开头的三个问题可以得到回答什么情况下需要bind(this)?
答: onClick传入的事件处理函数是普通函数的时候,需要bind(this)来改变指向为什么要用bind(this)?
答:如果不用bind(this), this会指向undefined可以不用bind(this)吗?
答:用箭头函数 (用箭头函数定义事件处理函数)感谢各位的阅读,以上就是“react点击事件的写法有哪些”的内容了,经过本文的学习后,相信大家对react点击事件的写法有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: golang怎么优雅的关机或重启

本文小编为大家详细介绍“golang怎么优雅的关机或重启”,内容详细,步骤清晰,细节处理妥当,希望这篇“golang怎么优雅的关机或重启”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。我们编写的Web项目部署之后,经常会因为需要进行配…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 04/23 19:54
下一篇 04/23 22:04

相关推荐