>首页> IT >

react点击事件的几种写法是什么

时间:2022-04-22 10:56:58       来源:PHP中文网

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react点击事件的几种写法是什么

开门见山,先直接给出为一个button添加一个事件的正确写法:

为一个button添加一个onclick事件的正确写法

不传参数
// handleClick用箭头函数定义时,为onClick添加事件应该这么写:

handleClick这么定义:

handleClick = () => { // do something here};

// handleClick用普通函数定义时,为onClick添加事件应该这么写:

handleClick这么定义:

handleClick () { // do something here }
传参数
// handleClick可以是箭头函数,也可以是普通函数

接下来分析一下为什么这样写是正确的:

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 (            

// 1. 为onClick绑定 handleClick事件处理函数

) }}export default examplePage;

点击按钮,打印出指向examplePage的this:

分析:

当点击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 (            

// 1. 为onClick绑定 handleClick事件处理函数

) }}export default examplePage;

点击按钮,打印出this:

分析:

当点击Button,调用handleClick事件处理函数,因为handleClick是一个普通函数,因此 this是 执行时上下文的this ,handleClick在页面中点击Button时执行的 ,上下文环境是html的那个页面所以this是undefined,并不指向examplePage

因此需要用bind来改变this指向,即:

render() {    return (        

// 用bind改变this指向

)}

分析:

当点击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 (        

// 通过箭头函数传参

)}

分析:

通过箭头函数传参数,相当于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)吗? 答:用箭头函数 (用箭头函数定义事件处理函数)
//定义handleClick事件handleClick = () => {      // do something here};//为onClick绑定handleClick事件处理函数 // 不传参 // 传参

推荐学习:《react视频教程》

以上就是react点击事件的几种写法是什么的详细内容,更多请关注php中文网其它相关文章!

关键词: 事件处理