react事件的问题

本文探讨了React中事件处理的两种常见方法,揭示了它们之间的微妙区别。代码示例显示,直接调用函数会导致在组件挂载时立即执行,而非在点击时。为了解决这个问题,文章介绍了两种解决方案:使用`bind`和箭头函数来确保事件处理函数在正确的时间被调用。通过这两个方法,可以确保React事件处理正常工作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

react的事件是我们学习react必会学习的,react事件处理会有多种方法,也有一种不经意的小问题。下面一起看看react事件处理问题

//代码一
import React from 'react'

class App extends React.Component {

    submit(){
        console.log('你点击')
    }

    render() {
        return (
           <div onClick={this.submit}>点击</div>
        )
    }
}
export default App;

//代码二
import React from 'react'

class App extends React.Component {

    submit(){
        console.log('你点击')
    }

    render() {
        return (
           <div onClick={this.submit()}>点击</div>
        )
    }
}
export default App;

上面二段代码的相差不大,但是结果是二种不同的结果,代码一点击才会去触发事件,二代码而当运行的时候,就会去触发事件,后者声明时就直接执行了(因而加载页面自动执行),执行后的返回值赋给了onClick属性(返回值必然不会是个函数,因而再点击没有作用)
在这里插入图片描述
那么解决这个问题我们可以改变this指向。就可以解决了。
bind改变

<div onClick={this.submit.bind()}>点击</div>

箭头函数改变

 <div onClick={()=>{this.submit()}}>点击</div>

这个时候我们就会发现事件恢复正常。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值