React项目中关于onclick的学习

本文介绍了JavaScript中onClick事件的函数传递方式,探讨了无参数和带参数传递的正确格式,并展示了如何使用_.throttle进行节流操作,以提高性能。重点讲解了函数封装和参数传递的最佳实践。

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

onclick传递函数的格式

function = (e) => {
	console.log('我是一个函数',e)
}

<button 
	onclick={this.function}.    //无参数传递时的正确的写法
/>

<button 
	onclick={this.function(‘这是错误的写法’)}.    //有参数传递时的错误的写法
/>

因为{}的作用,就是执行,所以此时onclick的函数会立即执行
所以传递参数时的正确写法如下

<button 
	onclick={()=>{this.function(‘这是错误的写法’)}}.    //有参数传递时的正确的写法
/>

此时,onclick传递了一个函数,这个函数并未执行,当被点击后,这个函数执行,里边被包裹的函数也会执行,就可以在合适的时间传递参数了!
拓展:利用lodash 中的方法(_.throttle方法进行节流,表示1000毫秒内只能点一次)

<button 
	onclick={_.throttle
	(
	()=>{this.function(‘这是错误的写法’)}, 
	1000
	)
}    //有参数传递时的正确的写法
/>
<button
    className='locationControl'
    onClick={_.throttle(() => { this.putCenterLocation() }, 2000)}      //无参数传递时也可以的包裹写法,主要为了节流。
/>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值