解析JavaScript數(shù)組方法reduce
Array.prototype.reduce()
概述
reduce()方法是數(shù)組的一個實例方法(共有方法),可以被數(shù)組的實例對象調(diào)用。reduce() 方法接收一個函數(shù)作為累加器(accumulator),數(shù)組中的每個值(從左到右)開始縮減,最終為一個值。
語法
arr.reduce(callback[, initialValue]) {}
參數(shù)
回調(diào)函數(shù)中可以傳遞四個參數(shù)。
previousValue:上一次調(diào)用回調(diào)函數(shù)返回的值,或者是提供的初始值(initialValue)
currentValue:數(shù)組中當(dāng)前被處理的元素
currentIndex:當(dāng)前被處理元素在數(shù)組中的索引, 即currentValue的索引.如果有initialValue初始值, 從0開始.如果沒有從1開始
array:調(diào)用 reduce 的數(shù)組
initialValue:可選參數(shù), 作為第一次調(diào)用 callback 的第一個參數(shù)
返回值
reduce()返回值是最后一次調(diào)用回調(diào)函數(shù)返回的結(jié)果
描述
reduce 為數(shù)組中的每一個元素依次執(zhí)行回調(diào)函數(shù),不包括數(shù)組中被刪除或從未被賦值的元素,接受四個參數(shù):
- previousValu 上一次值
- currentValue 當(dāng)前值
- currentIndex 當(dāng)前值的索引
- array 數(shù)組
回調(diào)函數(shù)第一次執(zhí)行時,previousValue 和 currentValue可能是兩個不同值其中的一個,如果reduce有initialValue參數(shù),那么 previousValue 等于 initialValue ,并且currentValue 等于數(shù)組中的第一個值;如果reduce沒有 initialValue 參數(shù),那么previousValue 等于數(shù)組中的第一個值,currentValue等于數(shù)組中的第二個值。
注意: 如果沒有initialValue參數(shù), reduce從index為1開始執(zhí)行回調(diào)函數(shù), 跳過第一個index。 如果有initialValue參數(shù), reduce 將從index為 0 開始執(zhí)行回調(diào)
如果數(shù)組是空的并且沒有initialValue參數(shù), 將會拋出TypeError錯誤. 如果數(shù)組只有一個元素并且沒有初始值initialValue, 或者有initialValue但數(shù)組是空的, 這個唯一的值直接被返回而不會調(diào)用回調(diào)函數(shù)。
通常來說提供一個initialValue初始值更安全一點, 因為沒有的話會出現(xiàn)如下輸出結(jié)果。
//沒有提供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);
回調(diào)被執(zhí)行四次,每次的參數(shù)和返回值如下表:
reduce 的返回值是回調(diào)函數(shù)最后一次被調(diào)用的返回值(10)。
如果把初始值作為第二個參數(shù)傳入 reduce,結(jié)果如下,結(jié)果如下:
[0, 1, 2, 3, 4].reduce((previousValue, currentValue, index, array) => previousValue + currentValue, 10);
最后一次函數(shù)調(diào)用的返回值 (20) 作為reduce函數(shù)的結(jié)果被返回
注意:添加了initialValue參數(shù)會多調(diào)用一次回調(diào)函數(shù)
例題
將數(shù)組所有項相加
let sum = [0, 1, 2, 3, 4].reduce((x, y) => x + y, 0); // 10
扁平化一個二維數(shù)組
let arr = [[1, 2], [3, 4], [5, 6]].reduce((x, y) => x.concat(y), []); // [1, 2, 3, 4, 5, 6]
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)鼠標(biāo)拖拽效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)鼠標(biāo)拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10解決ie11 SCRIPT5011:不能執(zhí)行已釋放Script的代碼問題
這篇文章主要介紹了ie11 SCRIPT5011:不能執(zhí)行已釋放Script的代碼 ,需要的朋友可以參考下2019-05-05微信小程序獲取用戶信息的兩種方法wx.getUserInfo與open-data實例分析
這篇文章主要介紹了微信小程序獲取用戶信息的兩種方法wx.getUserInfo與open-data,結(jié)合實例形式分析了wx.getUserInfo與open-data獲取用戶信息的相關(guān)操作技巧與使用注意事項,需要的朋友可以參考下2019-05-05JavaScript 判斷一個對象{}是否為空對象的簡單方法
下面小編就為大家?guī)硪黄狫avaScript 判斷一個對象{}是否為空對象的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10