微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我想逐行打印一个数组与回车.

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

1
2
3

现在,如果我使用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

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

在像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

解决方法:

看来这段代码在这里

[1,2,3].forEach(console.log)

是相同的:

[1,2,3].forEach((value, index, array) => console.log(value, index, array))

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

但如果您不喜欢这种行为,可以在Javascript中修复它.创建一个接受一个参数的简单函数

function print(t) { console.log(t) }

后执行

[1,2,3].forEach(print)

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

1
2
3

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

相关推荐