[英]Is there syntactic sugar for calling a function on each element of a list in JavaScript?
假设我有以下代码:
let array = [1, 2, 3]
array.forEach(x => someFunc(x))
在 Java 中,我知道第二行可以使用Stream
更简单(至少对于静态方法),如下所示:
array.stream().map(ClassName::someFunc) ...
本质上,我问的是 JavaScript 中的ClassName::someFunc
部分是否有模拟,而不必编写x => someFunc(x)
?
是的,不需要将“someFunc”包装在匿名() =>
“箭头函数”中
只要 someFunc 的第一个参数配置为从数组中接受当前迭代的项目并对其进行处理,那么您就可以传入对该函数的引用作为.forEach
中的参数(但不要调用它)。
所以你会这样做:
let array = [1, 2, 3]
array.forEach(someFunc)
确保不要这样做:
let array = [1, 2, 3]
array.forEach(someFunc())
(注意调用括号,这很糟糕)
在最简单的情况下,您可以替换
array.forEach(x => someFunc(x))
只需
array.forEach(someFunc)
但是您应该注意一些细则:
这通常不适用于对象方法: .forEach(someObj.someMeth)
不起作用
回调应该只接受一个参数或符合forEach
调用约定callback(element, index, this)
。 例如, array.map(parseInt)
也不起作用,因为parseInt
对第二个参数的含义有自己的想法。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.