JavaScript中数组的reduce方法

介绍

我们先来看看这个方法的官方概述:reduce()方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值。

你一定也和我一样看的有点迷糊,其实reduce接收的就是一个回调函数,去调用数组里的每一项,直到数组结束。


我们来举个例子大家就很明白了。

假设我有一串数组,数组里放的全是数字,我要算出这些数字的总和是多少。正常情况下我们会循环,然后一个个加,有了reduce就不用那么麻烦了,只用一行代码。

vartotal = [0,1,2,3,4].reduce((a, b)=>a + b);//10

这个方法是如何工作的呢?

reduce接受一个函数,函数有四个参数,分别是:

1、上一次的值;

2、当前值;

3、当前值的索引;

4、数组;

我们还是以上面那个数组为例,把这几个参数打印出来看看:

[0, 1, 2, 3, 4].reduce(function(previousValue, currentValue, index, array){

return previousValue + currentValue;

});

得到的结果是:


分析一下这个结果,这个回调函数共调用了4次,因为第一次没有previousValue,所以直接从数组的第二项开始,一只调用到数组结束。

reduce还有第二个参数,我们可以把这个参数作为第一次调用callback时的第一个参数,上面这个例子因为没有第二个参数,所以直接从数组的第二项开始,如果我们给了第二个参数为5,那么结果就是这样的:

[0, 1, 2, 3, 4].reduce(function(previousValue, currentValue, index, array){

return previousValue + currentValue;

},5);


第一次调用的previousValue的值就用传入的第二个参数代替,函数被调用了5次,也就是数组的length。

reduce可以帮助我们轻松的完成很多事,除了累加,还有扁平化一个二维数组:

varflattened = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {

    return  a.concat(b);

}, []);

// flattened == [0, 1, 2, 3, 4, 5]

总结

我暂时能想到的常用的就这两个,不过肯定还有很多地方能用到啦。以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 定义和用法:reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。注...
    黄怼怼阅读 860评论 0 0
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,272评论 0 4
  • 86.复合 Cases 共享相同代码块的多个switch 分支 分支可以合并, 写在分支后用逗号分开。如果任何模式...
    无沣阅读 1,449评论 1 5
  • 今天,在这里立一个Flag! 今天周四,没什么特别,稀松平常。 也就是一天不吃饭,但不觉饿。朋友羡慕地看我说:你这...
    我是王嘉译阅读 482评论 0 0
  • 一个人, 一杯白开水。 日子,怎么就过到了淡若清水? 偷偷地守住心里那份单纯, 怕被岁月无情剥夺。 心里不厌其烦的...
    喂鱼的Tom阅读 356评论 0 1