【问题标题】:Is there syntactic sugar for calling a function on each element of a list in JavaScript?是否有用于在 JavaScript 列表的每个元素上调用函数的语法糖?
【发布时间】:2022-07-07 22:45:04
【问题描述】:

假设我有以下代码:

let array = [1, 2, 3]
array.forEach(x => someFunc(x))

在 Java 中,我知道使用 Streams(至少对于静态方法而言)第二行会更简单,如下所示:

array.stream().map(ClassName::someFunc) ...

基本上我是在问 JavaScript 中的 ClassName::someFunc 部分是否有模拟,而不必编写 x => someFunc(x)

【问题讨论】:

  • array.forEach(someFunc) 或使用map array.map(someFunc)

标签: javascript foreach stream syntactic-sugar


【解决方案1】:

在最简单的情况下,你可以替换

array.forEach(x => someFunc(x))

只有

array.forEach(someFunc)

但您应该注意一些细则:

  • 这通常不适用于对象方法:.forEach(someObj.someMeth) 不起作用

  • 回调应该只接受一个参数或符合forEach 调用约定callback(element, index, this)。例如,array.map(parseInt) 也不起作用,因为parseInt 对第二个参数的含义有自己的想法。

【讨论】:

  • 我明白了。如果我有类似函数数组的东西,我想调用每个函数怎么办?我还能用array.forEach(func) 代替array.forEach(func => func()) 吗?
【解决方案2】:

是的,不需要将“someFunc”包装在匿名 () =>“箭头函数”中

只要 someFunc 的第一个参数被配置为从数组中接受当前迭代的项目并对其进行处理,那么您就可以传入对该函数的引用作为 .forEach 中的参数(但不要调用它)。

所以你会这样做:

let array = [1, 2, 3]
array.forEach(someFunc)

确保不要这样做:

let array = [1, 2, 3]
array.forEach(someFunc())

(注意调用括号,这是不好的)

【讨论】:

    猜你喜欢
    • 2011-03-23
    • 2020-03-18
    • 2016-01-24
    • 2014-09-24
    • 2012-01-14
    • 2010-09-22
    • 1970-01-01
    相关资源
    最近更新 更多