目录
react点击事件的几种写法是什么
this的指向分析" >this的指向分析
1. onClick = { this.handleClick } + 箭头函数" >1. onClick = { this.handleClick } + 箭头函数
2. onClick = { this.handleClick.bind(this) } + 普通函数" >2. onClick = { this.handleClick.bind(this) } + 普通函数
3. onClick = { (params) => this.handleClick(params) } + 普通函数/箭头函数都可" >3. onClick = { (params) => this.handleClick(params) } + 普通函数/箭头函数都可
首页 web前端 前端问答 react点击事件的几种写法是什么

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

Apr 22, 2022 am 10:28 AM
react

写法:1、用“onClick={this.handleClick}”;2、用“onClick={this.handleClick.bind(this)}”;3、用“{(params)=>this.handleClick(params)}”。

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

本教程操作环境: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点击事件的几种写法是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何利用React和WebSocket构建实时聊天应用 如何利用React和WebSocket构建实时聊天应用 Sep 26, 2023 pm 07:46 PM

如何利用React和WebSocket构建实时聊天应用引言:随着互联网的快速发展,实时通讯越来越受到人们的关注。实时聊天应用已经成为现代社交和工作生活中不可或缺的一部分。本文将介绍如何利用React和WebSocket构建一个简单的实时聊天应用,并提供具体的代码示例。一、技术准备在开始构建实时聊天应用之前,我们需要准备以下技术和工具:React:一个用于构建

React前后端分离指南:如何实现前后端的解耦和独立部署 React前后端分离指南:如何实现前后端的解耦和独立部署 Sep 28, 2023 am 10:48 AM

React前后端分离指南:如何实现前后端的解耦和独立部署,需要具体代码示例在当今的Web开发环境中,前后端分离已经成为一种趋势。通过将前端和后端代码分开,可以使得开发工作更加灵活、高效,并且方便进行团队协作。本文将介绍如何使用React实现前后端分离,从而实现解耦和独立部署的目标。首先,我们需要理解什么是前后端分离。传统的Web开发模式中,前端和后端是耦合在

如何利用React和Flask构建简单易用的网络应用 如何利用React和Flask构建简单易用的网络应用 Sep 27, 2023 am 11:09 AM

如何利用React和Flask构建简单易用的网络应用引言:随着互联网的发展,网络应用的需求也越来越多样化和复杂化。为了满足用户对于易用性和性能的要求,使用现代化的技术栈来构建网络应用变得越来越重要。React和Flask是两种在前端和后端开发中非常受欢迎的框架,它们可以很好的结合在一起,用来构建简单易用的网络应用。本文将详细介绍如何利用React和Flask

如何利用React和RabbitMQ构建可靠的消息传递应用 如何利用React和RabbitMQ构建可靠的消息传递应用 Sep 28, 2023 pm 08:24 PM

如何利用React和RabbitMQ构建可靠的消息传递应用引言:现代化的应用程序需要支持可靠的消息传递,以实现实时更新和数据同步等功能。React是一种流行的JavaScript库,用于构建用户界面,而RabbitMQ是一种可靠的消息传递中间件。本文将介绍如何结合React和RabbitMQ构建可靠的消息传递应用,并提供具体的代码示例。RabbitMQ概述:

React代码调试指南:如何快速定位和解决前端bug React代码调试指南:如何快速定位和解决前端bug Sep 26, 2023 pm 02:25 PM

React代码调试指南:如何快速定位和解决前端bug引言:在开发React应用程序时,经常会遇到各种各样的bug,这些bug可能使应用程序崩溃或导致不正确的行为。因此,掌握调试技巧是每个React开发者必备的能力。本文将介绍一些定位和解决前端bug的实用技巧,并提供具体的代码示例,帮助读者快速定位和解决React应用程序中的bug。一、调试工具的选择:在Re

React Router使用指南:如何实现前端路由控制 React Router使用指南:如何实现前端路由控制 Sep 29, 2023 pm 05:45 PM

ReactRouter使用指南:如何实现前端路由控制随着单页应用的流行,前端路由成为了一个不可忽视的重要部分。ReactRouter作为React生态系统中最受欢迎的路由库,提供了丰富的功能和易用的API,使得前端路由的实现变得非常简单和灵活。本文将介绍ReactRouter的使用方法,并提供一些具体的代码示例。安装ReactRouter首先,我们需

如何利用React和Google BigQuery构建快速的数据分析应用 如何利用React和Google BigQuery构建快速的数据分析应用 Sep 26, 2023 pm 06:12 PM

如何利用React和GoogleBigQuery构建快速的数据分析应用引言:在当今信息爆炸的时代,数据分析已经成为了各个行业中不可或缺的环节。而其中,构建快速、高效的数据分析应用则成为了许多企业和个人追求的目标。本文将介绍如何利用React和GoogleBigQuery结合起来构建快速的数据分析应用,并提供详细的代码示例。一、概述React是一个用于构建

如何利用React和Docker打包和部署前端应用 如何利用React和Docker打包和部署前端应用 Sep 26, 2023 pm 03:14 PM

如何利用React和Docker打包和部署前端应用前端应用的打包和部署是项目开发中非常重要的一环。随着现代前端框架的飞速发展,React已经成为了许多前端开发人员的首选。而Docker作为一种容器化解决方案,可以极大地简化应用的部署过程。本文将介绍如何利用React和Docker打包和部署前端应用,并提供具体的代码示例。一、准备工作在开始之前,我们需要先安装

See all articles