带有胖箭头的数组上的forEach循环

Mic*_*Hua 5 javascript arrays lambda scala

我想用回车符逐行打印一个数组。

简单的实现是[1,2,3].forEach(function(x) {console.log(x)})将其作为输出

1
2
3
Run Code Online (Sandbox Code Playgroud)

现在,如果我使用ES6胖箭头的语法糖,

michel$ node
> [1,2,3].forEach(x => console.log(x))
1
2
3
undefined
>
> [1,2,3].forEach(console.log)
1 0 [ 1, 2, 3 ]
2 1 [ 1, 2, 3 ]
3 2 [ 1, 2, 3 ]
undefined
Run Code Online (Sandbox Code Playgroud)

forEach回调中省略function参数时,看起来第二个版本正在返回其自身的笛卡尔积。

在其他功能语言(例如Scala)中,这完全可以,为什么在JavaScript中这是“错误的”?

michel$ scala
scala> Array(1,2,3).foreach(x => println(x))
1
2
3

scala> Array(1,2,3).foreach(println)
1
2
3
Run Code Online (Sandbox Code Playgroud)

Nje*_*rus 7

你可以像这样使用 ES6 'fat' 箭头。

     const data = [1,2,3,4]

     data.forEach(item => {
         console.log(item)
     })
Run Code Online (Sandbox Code Playgroud)


gil*_*des 5

似乎这段代码在这里:

[1,2,3].forEach(console.log)
Run Code Online (Sandbox Code Playgroud)

是相同的:

[1,2,3].forEach((value, index, array) => console.log(value, index, array))
Run Code Online (Sandbox Code Playgroud)

与Scala或Java(方法引用)相比,它似乎支持一个单一参数的方法引用,这不是“错误”,而是“异常”。Javascript似乎只是将所有参数复制到引用的方法(例如console.log),如果此方法支持varargs,则所有内容都会得到处理。

但是,如果您不喜欢这种行为,则可以使用Javascript修复它。创建一个接受一个参数的简单函数:

function print(t) { console.log(t) }
Run Code Online (Sandbox Code Playgroud)

然后执行:

[1,2,3].forEach(print)
Run Code Online (Sandbox Code Playgroud)

这将打印出结果,如果您来自Scala背景,它将使您有宾至如归的感觉:

1
2
3
Run Code Online (Sandbox Code Playgroud)