登录  /  注册

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

WBOY
发布: 2022-04-22 10:28:08
原创
2449人浏览过

写法: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></button>
登录后复制

handleClick这么定义:

handleClick = () =&gt; { // do something here};
登录后复制

// handleClick用 (普通函数) 定义
onClick = { this.handleClick.bind(this) }

// handleClick用普通函数定义时,为onClick添加事件应该这么写:<button></button>
登录后复制

handleClick这么定义:

handleClick () { // do something here }
登录后复制
  • 传参数

// handleClick用 /(普通函数) 定义都可以
onClick = { (params) => this.handleClick(params) }

 // handleClick可以是箭头函数,也可以是普通函数<button> this.handleClick(params) }&gt;</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 = () =&gt; {
        console.log(this); //3. this指向examplePage
    }

    render() {
        return (
            <p>
            // 1. 为onClick绑定 handleClick事件处理函数
                <button>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>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>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> this.handleClick(params) }&gt;</button>
        </p>
    )}
登录后复制

分析:

  • 通过箭头函数传参数,相当于onClick绑定了一个箭头函数
  • 点击Button时,调用(params) => this.handleClick(params)这个箭头函数,因此 this是 定义时上下文的this ,
  • handleClick在class examplePage 中定义的 ,
  • 所以this指向examplePage
  • 按这种思路,只要把onClick的响应事件用箭头函数来写,调用的时候,this指向的都是该组件class,就不会有问题

那么,不传参的时候,就这么写:

<button> this.handleClick() }&gt;</button>
登录后复制

但这是不可行的,因为react会直接解析()=> this.handleClick(), handleClick会被调用,相当于onClick = “调用handleClick的结果”

所以,不传参数的时候只能这么写:

<button></button>
登录后复制

总结
开头的三个问题可以得到回答

  • 什么情况下需要bind(this)?
    答: onClick传入的事件处理函数是普通函数的时候,需要bind(this)来改变指向
  • 为什么要用bind(this)?
    答:如果不用bind(this), this会指向undefined
  • 可以不用bind(this)吗?
    答:用箭头函数 (用箭头函数定义事件处理函数)
//定义handleClick事件
handleClick = () => {
      // do something here
};

//为onClick绑定handleClick事件处理函数
<button></button> // 不传参
 // 传参
登录后复制

推荐学习:《react视频教程

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

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号