如图所示,为什么传递参数为e时不用写成箭头函数,但是传递自定义参数要写成箭头函数的形式?
react事件绑定传自定义参数时为什么把事件监听写成箭头函数的形式
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
关注 引自免费微信小程序:皆我百晓生
在React中,当您使用箭头函数作为事件处理程序时,它可以帮助解决一些与
this
上下文相关的问题。通常,在JavaScript中,当一个函数被当作事件处理器(如onClick)调用时,它的this
关键字会指向触发这个事件的元素。然而,如果您使用传统的函数声明(即非箭头函数),那么this
可能不会像预期那样指向组件实例。在您的例子中,
clickHandler
是一个普通的函数,所以它内部的this
将根据其执行环境而变化。为了确保clickHandler
中的this
始终指向正确的组件实例,您可以选择使用箭头函数,因为箭头函数没有自己的this
,它会从其所在的作用域链中继承this
值。在这种情况下,由于箭头函数是在AppO组件的上下文中定义的,因此this
将始终指向AppO组件。下面是将
clickHandler
改为箭头函数的版本:function AppO() { const handleClick = (name) => { console.log('button按钮点击了', name); }; return ( <button onClick={() => handleClick('jack')}> Click me </button> ); }
在这个修改后的版本中,我们创建了一个名为
handleClick
的箭头函数,并将其作为onClick
事件处理程序。当我们点击按钮时,handleClick
函数会被调用,而且this
会正确地指向AppO组件,同时也会传递给定的名字'jack'作为参数。总结一下,使用箭头函数作为事件处理程序的好处是它们不会创建自己的
this
上下文,这样可以避免在组件方法中对this
的引用出现问题。对于传递自定义参数的情况,无论是箭头函数还是普通函数都可以完成任务,但使用箭头函数可以简化代码并避免潜在的this
上下文问题。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
- ¥50 浦育平台scratch图形化编程
- ¥20 求这个的原理图 只要原理图
- ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
- ¥20 微信的店铺小程序如何修改背景图
- ¥15 UE5.1局部变量对蓝图不可见
- ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
- ¥20 sentry如何捕获上传Android ndk 崩溃
- ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
- ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?