Skip to content
On this page

什么情况下会使用array.reduce函数

当业务需要从一个数组里求出某项的和的时候, 往往定义一个变量, 然后去遍历每项, 用变量去累加.

js
var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

var resulte = 0;

for (let index = 0; index < a.length; index++) {
    resulte += a[index];
}

console.log(resulte); //55

又或者会去这样实现

js
var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

var resulte = 0;

a.forEach(i => resulte += i)

console.log(resulte); //55

其实js的数组内置函数早已经帮我们实现好了

js
var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

const INITVAL = 0;//默认从0开始累加,可要可不要

var resulte = a.reduce((prev, item) => prev + item, INITVAL)

console.log(resulte); //55

reduce使用教程

如何实现一个简单的reduce

reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值.
对于空数组是不会执行回调函数的。

js
Array.prototype.myReduce = function (cb, initVal) {
    var resulte = initVal;
    var len = this.length;
    var i = 0;
    //空数组不执行
    if (len === 0) {
        return console.log('数组不能为空')
    }
    //initVal如果不为空,索引+1
    if (initVal === undefined) {
        resulte = this[i]
        i = 1
    } 
    for (i; i < len; i++) {
        var item = this[i];
        resulte = cb(resulte, item, i);
    }
    return resulte
}

var b = [1, 3, 4, 5, 6]
var persons = [
    {
        name: "张三",
        age: 18
    }, {
        name: "李四",
        age: 36
    }
]

var agesum= persons.myReduce((a,c)=> a+c.age,0)
var r = b.myReduce(function (pre, item, index) {
    console.log(pre, item, index); //上一个值, 遍历的当前项 , 索引
    return pre + item
}, 7)
console.log(r);
console.log(agesum);