首頁 >web前端 >js教程 >解析JavaScript數組方法reduce

解析JavaScript數組方法reduce

高洛峰
高洛峰原創
2016-12-28 09:48:471151瀏覽

Array.prototype.reduce()

概述

reduce()方法是數組的一個實例方法(共有方法),可以被數組的實例物件呼叫。 reduce() 方法接收一個函數作為累加器(accumulator),數組中的每個值(從左到右)開始縮減,最終為一個值。

語法

arr.reduce(callback[, initialValue]) {}

參數

回呼函數中可以傳遞四個參數。

previousValue:上一次呼叫回呼函數傳回的值,或是提供的初始值(initialValue)

currentValue:陣列中目前被處理的元素

currentIndex:目前被處理元素在陣列中的索引, 即currentValue的索引索引.如果有initialValue初始值, 從0開始.如果沒有從1開始

array:調用reduce 的數組

initialValue:可選參數, 作為第一次調用callback 的第一個參數

返回值

reduce()傳回值是最後一次呼叫回呼函數傳回的結果

描述

reduce 為數組中的每一個元素依序執行回呼函數,不包括數組中被刪除或從未被賦值的元素,接受四個參數:

previousValu 上一次值

currentValue 目前值

currentIndex 目前值的索引

array 陣列

回呼函數第一次執行時,其中previousValue 和currentValue參數,那麼previousValue 等於initialValue ,而currentValue 等於數組中的第一個值;如果reduce沒有initialValue 參數,那麼previousValue 等於數組中的第一個值,currentValue等於數組中的第二個值。

注意: 如果沒有initialValue參數, reduce從index為1開始執行回呼函數, 跳過第一個index。 如果有initialValue參數, reduce 將從index為0 開始執行回呼

如果數組是空的並且沒有initialValue參數, 將會拋出TypeError錯誤. 如果數組只有一個元素並且沒有初始值initialValue, 或者有initialValue但數組是空的, 這個唯一的值直接被傳回而不會呼叫回呼函數。

通常來說提供一個initialValue初始值更安全一點, 因為沒有的話會出現如下輸出結果。

//没有提供initialValue
function foo(){
 return [1,2,3,4,5].reduce((x, y) => x + y); //15
};
console.log(foo.call(this));
function foo(){
 return [].reduce((x, y) => x + y); //TypeError
};
console.log(foo.call(this));
//提供initialValue
function foo(){
 return [].reduce((x, y) => x + y, 0); //0
};
console.log(foo.call(this));

reduce()是如何運作的

[0, 1, 2, 3, 4].reduce((previousValue, currentValue, index, array) => previousValue + currentValue);

回調被執行四次,每次的參數和回傳值如下表:

解析JavaScript數組方法reduce

reduce 的回傳值是回呼函數最後一次被呼叫的回傳值(10 )。

如果把初始值作為第二個參數傳入reduce,結果如下,結果如下:

[0, 1, 2, 3, 4].reduce((previousValue, currentValue, index, array) => previousValue + currentValue, 10);

解析JavaScript數組方法reduce

最後一次函數調用的返回值(20) 作為reduce函數的結果被返回

注意:添加了initialValue參數會多呼叫一次回呼函數

例題

將數組所有項相加

let sum = [0, 1, 2, 3, 4].reduce((x, y) => x + y, 0); 
// 10

扁平化一個二維數組

let arr = [[1, 2], [3, 4], [5, 6]].reduce((x, y) => x.concat(y), []);
// [1, 2, 3, 4, 5, 6]

以上就是本文的全部內容,希望本文的內容對大家的學習或工作能帶來一定的幫助,同時也希望多多支援PHP中文網!

更多解析JavaScript數組方法reduce相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn