數組的reduce方法


 

arr.reduce(callback(accumulator, currentValue, index, array), initialValue);

如果沒有initialValue,默認數組的第一項為initialValue,第一次的currentValue為數組的第二項:

//沒有提供initialValue
function foo(){
    return [1,2,3,4,5].reduce((x, y) => x + y);   //15
};

 

reduce方法有兩個參數,第一個參數是操作數組項的函數;第二個參數則是傳入的初始值,reduce最常用的方法是疊加,以下例子可以看出,reduce函數根據初始值0,不斷的疊加數組項:

var items = [10, 120, 1000];

// sumSoFar第一次初始值是1,item第一次初始值是數組的第一個元素即10;
var total = items.reduce(function add(sumSoFar, item) { 
    // 1 10
    // 11 120
    // 131 1000
    console.log(sumSoFar, item);
    return sumSoFar + item;  // 這個值會變成下一次的sumSoFar 
}, 1);

console.log(total); // 1131    

reduce函數的返回結果類型和傳入的初始值相同,上個例子中初始值為number類型,初始值也可為object類型:

var items = [10, 120, 1000];

// sumSoFar第一次即初始值{sum: 0},item第一次為數組的第一個元素
var total = items.reduce(function (sumSoFar, item){
        // {sum: 0} 10
        // {sum: 10} 120
        // {sum: 130} 1000
        console.log(sumSoFar, item);
        sumSoFar.sum = sumSoFar.sum + item; // 對sumSoFar對象的值sum進行處理,累加數組里的每一項
        return sumSoFar; // 返回處理后的sumSoFar對象
}, {sum: 0});

console.log(total); // {sum:1130}
var arr = [1,2,3,4,5,6,7,3,4,5,2,2,2];

// p第一次為初始值{},k第一次為數組的第一個元素,之后每次迭代p為為處理后(p[k]++ || (p[k] = 1))的p
var info = arr.reduce(function(p,k){
        p[k]++ || (p[k] = 1);
        return p;
}, {});

console.log(info);  // {1: 1, 2: 4, 3: 2, 4: 2, 5: 2, 6: 1, 7: 1}

 原文:https://www.cnblogs.com/accordion/p/5230287.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM