JavaScript 中 6 个 reduce() 实例
reduce 方法在数组的每个元素上执行提供的回调函数迭代器。它传入前一个元素计算的返回值,结果是单个值,它是在数组的所有元素上运行迭代器的结果。
迭代器函数逐个遍历数组的元素,在每一步中,迭代器函数将当前数组值添加到上一步的结果中,直到没有更多元素要添加。
语法
参数包含回调函数和可选的初始值,如下:
array.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
回调函数
回调函数接受一下四个参数:
accumulator
:前一个回调函数产生的前一个值,即累计器currentValue
:数组遍历的当前元素,即当前值currentIndex
:当前索引sourceArray
:原数组
初始值
初始值参数是可选的,它是第一次调用回调时将前一个值初始化为的值。如果未指定初始值,则将前一个值初始化为初始值,将当前值初始化为数组中的第二个值。
reduce()
方法是一种有价值的方法,在某些情况下,它可能会节省时间或减少编码的行数。在本文中,将展示 JavaScript 中 reduce()
方法的六个实例。
1. 数组求和
2. 数组展平
使用 reduce()
,可以很容易将多维数组转换为一维集合。
3. 创建 Pipeline
此外,可以减少函数以及数字和字符串,假设有一系列数学函数。例如,有以下功能:
此外,希望对订单使用 increment
、double
和 decrement
。因此,可以为此创建管道。然后,可以将它与 reduce()
一起使用。
4. 数组重复项计算
例如,有一个字符串数组,它们是一个颜色数组,使用 reduce()
将其中每种颜色的重复次数计算出来,如下:
5. 数组中出现奇数次的整数
使用 reduce()
来查找在给定数组中出现奇数次的整数,如下:
6. 查找数组的最大子数组和
使用此函数,可以找到给定数组的最大子数组和,如下:
总结
了解 JavaScript 中一些内置高阶函数的用例,可以帮助提高编码技能。
版权声明: 本文为 InfoQ 作者【devpoint】的原创文章。
原文链接:【http://xie.infoq.cn/article/a732efa0375954952e499c0fb】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论