为什么我必须在 React 事件处理程序中放置一个箭头函数而不仅仅是返回值?

如何解决为什么我必须在 React 事件处理程序中放置一个箭头函数而不仅仅是返回值?

我看过一些教科书和博客文章,但大多数似乎只是在没有明确解释的情况下喃喃自语......

在 React 的事件处理程序中,我被告知要写,

onChange = {() => setValue(someValue)}

onChange = {() => this.props.someFunction(someValue)}

我只是不明白为什么我不能简单地写一些类似的东西

onChange = {setValue(someValue)}

onChange = {this.props.someFunction(someValue)}

由于在我的理解中 setValue 本身已经是一个函数,“() =>”对我来说看起来绝对是多余的。

另一方面,如果事件是在一个类中定义的,那么我可以这样写

onChange = {this.someFunction}

在这种情况下,为什么我不需要写成 aarow 函数呢?喜欢

onChange = {() => this.someFunction}

这不是双重标准吗???

解决方法

因为:

this.someFunction

还有这个:

this.someFunction()

是两个非常不同的东西。第一个是对函数本身的引用,而第二个执行函数并计算其返回值。

所以当你这样做时:

onChange = {this.someFunction}

你说的:

当值发生变化时,执行 this.someFunction 并将其传递给 change 事件。

但是当你这样做时:

onChange = {this.someFunction()}

你说的:

立即执行 this.someFunction ,不传递任何内容。当值改变时,执行任何 this.someFunction returned(它可能不是一个可执行函数)并将其传递给 change 事件。

箭头函数的目的是创建一个不存在的函数。所以如果你只有一个简单的函数引用,就传递它:

onChange = {this.someFunction}

但是假设您想做两件事,而不仅仅是调用那一个函数。在这种情况下,您可以将这两件事包装在一个匿名函数中:

onChange = {(e) => {
  this.someFunction(e);
  somethingElse();
}}

或者更简单,假设您有一个简单的函数引用,但它期望新的更改值而不是更改事件本身:

onChange = {(e) => this.someFunction(e.target.event)}

基本上,如果您还没有可以执行您想要的功能的函数,您就可以创建一个函数。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?