Array.prototype.reduce()

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Array.prototype.reduce()相关的知识,希望对你有一定的参考价值。

原文出处:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce

语法:arr.reduce(callback,[ initialValue])

var total = [0, 1, 2, 3].reduce(function(sum, value) {
      return sum + value;
    }, 1);
    console.log(total);//7

    var flattened = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {
      return a.concat(b);
    });
    console.log(flattened);//[0, 1, 2, 3, 4, 5]

reduce对数组中存在的每个元素执行一次回调函数,排除数组中的空格,接收四个参数:

  • accumulator
  • currentValue
  • currentIndex
  • array

第一次调用callback时,accumulator 和currentValue可以是两个值之一。如果在调用reduce中提供initialValue,则累加器将等于initialValue,而currentValue将等于数组中的第一个值。如果没有提供initialValue,则累加器将等于数组中的第一个值,而currentValue将等于第二个值。

注意:如果未提供initialValue,则reduce将执行回调函数,从索引1开始,跳过第一个索引。如果提供了initialValue,它将从索引0开始。

如果数组为空且没有提供initialValue,则将抛出TypeError。如果数组只有一个元素(不管位置),并且没有提供initialValue,或者如果提供了initialValue,但数组为空,则将返回那个元素的值而不调用回调。

以上是关于Array.prototype.reduce()的主要内容,如果未能解决你的问题,请参考以下文章

Array.prototype.reduce 的理解与实现

Using Array.prototype.reduce() to Reduce Conceptual Boilerplate for Problems on Arrays

为啥 Array.prototype.reduce() 不接受 Map 对象作为初始值?

如何正确使用 TypeScript 和 Array.prototype.reduce?

前端开发Array.prototype.reduce()的详细解析&使用

Array数组语法系列: Array.prototype.reduce