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