reduce函數(shù)20個(gè)高級(jí)用法 看看你掌握了多少耗啦?

什么是reduce函數(shù)

  1. reduce 方法對(duì)數(shù)組中的每個(gè)元素按序執(zhí)行一個(gè)提供的 reducer 函數(shù)
  2. 每一次運(yùn)行 reducer 會(huì)將先前元素的計(jì)算結(jié)果作為參數(shù)傳入岳守,最后將其結(jié)果匯總為單個(gè)返回值艾杏。

函數(shù)組成

reduce(callbackFn)
reduce(callbackFn, initialValue)

函數(shù)具體內(nèi)容

  1. reduce 方法是一個(gè)迭代方法。
  2. 它按升序?qū)?shù)組中的所有元素運(yùn)行一個(gè)“reducer”回調(diào)函數(shù)极颓,并將它們累積到一個(gè)單一的值中朱盐。
  3. 每次調(diào)用時(shí),callbackFn 的返回值都作為 accumulator 參數(shù)傳遞到下一次調(diào)用中菠隆。
  4. accumulator 的最終值(也就是在數(shù)組的最后一次迭代中從 callbackFn 返回的值)將作為 reduce() 的返回值兵琳。

函數(shù)示例

1.求和函數(shù)

const sum = (arr) => arr.reduce((acc, cur) => acc + cur, 0);
//累計(jì)值為acc
//當(dāng)前值為cur
//初始值為initialValue 為0
let arr = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("總和為:", sum(arr));

[圖片上傳失敗...(image-d77c86-1711469154118)]

2.求積函數(shù)

const product = (arr) => arr.reduce((acc, curr) => acc * curr, 1);
let arr1 = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr1);
console.log("乘積為:", product(arr1));

[圖片上傳失敗...(image-1eff1b-1711469154118)]

3.扁平化數(shù)組

const flatten = (arr) => arr.reduce((acc, curr) => acc.concat(curr), []);
let arr = [[1, 2], [3, 4], [5]];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", flatten(arr));

[圖片上傳失敗...(image-96e497-1711469154118)]

4.計(jì)算平均值(類似求和)

const average = (arr) => arr.reduce((acc, curr) => acc + curr, 0) / arr.length;
let arr = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", average(arr));

[圖片上傳失敗...(image-86a41-1711469154118)]

5.最大值

const max = (arr) => arr.reduce((acc, curr) => Math.max(acc, curr), Number.NEGATIVE_INFINITY);
let arr = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", max(arr));

[圖片上傳失敗...(image-4d61ab-1711469154118)]

6.最小值

const min = (arr) => arr.reduce((acc, curr) => Math.min(acc, curr), Number.POSITIVE_INFINITY);
let arr = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", min(arr));

[圖片上傳失敗...(image-10c0e1-1711469154118)]

7.階乘函數(shù)

const factorial = (n) => Array.from({ length: n }, (_, i) => i + 1).reduce((acc, curr) => acc * curr, 1);
//  Array.from({ length: n }, (_, i) => i + 1) 生成數(shù)組數(shù)據(jù) [1,2,3,4,5]
console.log("參數(shù)為:", 5);
console.log("結(jié)果為:", factorial(5));

[圖片上傳失敗...(image-70c822-1711469154118)]

8.數(shù)組去重

const unique = (arr) => arr.reduce((acc, curr) => acc.includes(curr) ? acc : [...acc, curr], []);
let arr = [1, 2,3,4,2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", unique(arr));

[圖片上傳失敗...(image-6d598b-1711469154118)]

9.元素計(jì)數(shù)

const countOccurrences = (arr) => arr.reduce((acc, curr) => {
    acc[curr] = (acc[curr] || 0) + 1;
    return acc;
}, {});

let arr = [1, 2,3,4,2, 3, 4, 5];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", countOccurrences(arr));

[圖片上傳失敗...(image-994351-1711469154118)]

10.并集函數(shù)

const union = (...arrays) => arrays.reduce((acc, curr) => [...new Set([...acc, ...curr])], []);

let arr = [1, 2,3,4,2, 3, 4, 5];
let arr1 = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr,arr1);
console.log("結(jié)果為:", union(arr,arr1));

[圖片上傳失敗...(image-8ac0b-1711469154118)]

11.交集函數(shù)

const intersection = (...arrays) => arrays.reduce((acc, curr) => acc.filter(value => curr.includes(value)));

let arr = [1, 2,3,4,2, 3, 4, 5];
let arr1 = [1, 2, 3, 4, 5];
console.log("參數(shù)為:", arr,arr1);
console.log("結(jié)果為:", intersection(arr,arr1));

[圖片上傳失敗...(image-91d77a-1711469154118)]

12.差集函數(shù)

const difference = (arr1, arr2) => arr1.reduce((acc, curr) => arr2.includes(curr) ? acc : [...acc, curr], []);

let arr = [1, 2,3,4,2, 3, 4, 5,9];
let arr1 = [1, 2, 3, 4, 5,7,8];
console.log("參數(shù)為:", arr,arr1);
console.log("結(jié)果為:", difference(arr,arr1));

[圖片上傳失敗...(image-bae439-1711469154118)]

13.對(duì)稱差集函數(shù)

const difference = (arr1, arr2) => arr1.reduce((acc, curr) => arr2.includes(curr) ? acc : [...acc, curr], []);
const symmetricDifference = (arr1, arr2) => [...difference(arr1, arr2), ...difference(arr2, arr1)];
let arr = [1, 2,3,4,2, 3, 4, 5,9];
let arr1 = [1, 2, 3, 4, 5,7,8];
console.log("參數(shù)為:", arr,arr1);
console.log("結(jié)果為:", symmetricDifference(arr,arr1));

[圖片上傳失敗...(image-3c4a0a-1711469154118)]

14.切片函數(shù)

const chunk = (arr, size) => arr.reduce((acc, _, i) => i % size === 0 ? [...acc, arr.slice(i, i + size)] : acc, []);

let arr = [1, 2,3,4,2, 3, 4, 5,9];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", chunk(arr,4));

[圖片上傳失敗...(image-43860f-1711469154118)]

15.分組函數(shù)

const groupBy = (arr, key) => arr.reduce((acc, obj) => {
    const groupKey = obj[key];
    acc[groupKey] = [...(acc[groupKey] || []), obj];
    return acc;
}, {});

let arr = [{ id: 1, name: '微芒不朽' }, { id: 2, name: '微芒' }, { id: 1, name: '微芒不朽' }];
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", groupBy(arr,"name"));

[圖片上傳失敗...(image-5ea117-1711469154118)]

16.去除falsy值

// 16. 數(shù)組去除假值
const compact = (arr) => arr.reduce((acc, curr) => curr ? [...acc, curr] : acc, []);
let arr = [0, 1, false, 2, '', 3]
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", compact(arr,"name"));

[圖片上傳失敗...(image-cec661-1711469154118)]

17.去除空元素

const removeEmpty = (arr) => arr.reduce((acc, curr) => curr ? [...acc, curr] : acc, []);

let arr = [0, 1, null, 2,undefined, '', 3]
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", removeEmpty(arr,"name"));

[圖片上傳失敗...(image-4a545f-1711469154118)]

18.去除指定元素

const removeItem = (arr, item) => arr.reduce((acc, curr) => curr === item ? acc : [...acc, curr], []);
let arr = [1, 2, 3, 4, 2, 5]
console.log("參數(shù)為:", arr);
console.log("結(jié)果為:", removeItem(arr,2));

[圖片上傳失敗...(image-fe5c98-1711469154118)]

19.元素映射

const mapArray = (arr, fn) => arr.reduce((acc, curr) => [...acc, fn(curr)], []);
let arr = [1, 2, 3, 4, 2, 5]
console.log("參數(shù)為:", arr,(x)=>x+2);
console.log("結(jié)果為:", mapArray(arr,(x)=>x+2));

[圖片上傳失敗...(image-fcceda-1711469154118)]

19.元素過濾

const filterArray = (arr, fn) => arr.reduce((acc, curr) => fn(curr) ? [...acc, curr] : acc, []);
let arr = [1, 2, 3, 4, 2, 5]
console.log("參數(shù)為:", arr,(x) => x % 2 === 0);
console.log("結(jié)果為:", filterArray(arr,(x) => x % 2 === 0));

[圖片上傳失敗...(image-eab9c3-1711469154118)]

console.log樣式函數(shù)【重寫console.log】

function randomColor() {
  let r = Math.floor(Math.random()*256);
  let g = Math.floor(Math.random()*256);
  let b = Math.floor(Math.random()*256);
  //返回隨機(jī)生成的顏色
  return "rgb("+r+","+g+","+b+")";
}
console.log = (function(oriLogFunc){
  return function(...data)
  {
    const icons = ["??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "??", "?", "??", "??", "??", "?", "?", "?", "?", "??"]
    const icon = icons[Math.floor(Math.random() * icons.length)];
    const bgColor = randomColor()
    const color = randomColor()
    oriLogFunc.call(console,`%c ${icon} `, `border-radius:5px;padding:12px;border:1px solid #000;color: #43bb88;font-size: 16px;font-weight: bold;text-decoration: underline;`, ...data);
  }
})(console.log);

[圖片上傳失敗...(image-484e38-1711469154119)]

參考資料

  1. https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce
  2. http://www.reibang.com/p/a2f2a7eeb662
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末狂秘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子躯肌,更是在濱河造成了極大的恐慌者春,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件羡榴,死亡現(xiàn)場(chǎng)離奇詭異碧查,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)校仑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來传惠,“玉大人迄沫,你說我怎么就攤上這事∝苑剑” “怎么了羊瘩?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)盼砍。 經(jīng)常有香客問我尘吗,道長(zhǎng),這世上最難降的妖魔是什么浇坐? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任睬捶,我火速辦了婚禮,結(jié)果婚禮上近刘,老公的妹妹穿的比我還像新娘擒贸。我一直安慰自己,他們只是感情好觉渴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布介劫。 她就那樣靜靜地躺著,像睡著了一般案淋。 火紅的嫁衣襯著肌膚如雪座韵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天踢京,我揣著相機(jī)與錄音誉碴,去河邊找鬼。 笑死漱挚,一個(gè)胖子當(dāng)著我的面吹牛翔烁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播旨涝,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼蹬屹,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼侣背!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起慨默,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤贩耐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后厦取,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體潮太,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年虾攻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了铡买。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡霎箍,死狀恐怖奇钞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情漂坏,我是刑警寧澤景埃,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站顶别,受9級(jí)特大地震影響谷徙,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜驯绎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一完慧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧条篷,春花似錦骗随、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乞巧,卻和暖如春涨椒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绽媒。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工蚕冬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人是辕。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓囤热,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親获三。 傳聞我的和親對(duì)象是個(gè)殘疾皇子旁蔼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 算法中使用的數(shù)據(jù)結(jié)構(gòu)解釋 在算法的執(zhí)行過程中锨苏,需要有能夠容納臨時(shí)數(shù)據(jù)的內(nèi)存數(shù)據(jù)結(jié)構(gòu)。數(shù)據(jù)結(jié)構(gòu)的有效實(shí)施需要選擇適當(dāng)...
    Python_Camp閱讀 390評(píng)論 0 1
  • 前言:應(yīng)屆/實(shí)習(xí)求職的學(xué)生棺聊,但凡有些iOS編碼能力(熟悉Runtime原理伞租、看過一些開源庫實(shí)現(xiàn)、有一定項(xiàng)目經(jīng)驗(yàn)等)...
    在ios寫bug的杰克閱讀 552評(píng)論 0 10
  • 前言 經(jīng)歷過寒冬之后,你會(huì)明白祟同,人才到哪兒都是需要的作喘,而且還是急缺,作為一個(gè)自學(xué)出來的前端開發(fā)工程師耐亏,經(jīng)歷了最原始...
    一只大橘閱讀 2,035評(píng)論 4 59
  • 1徊都、NSArray與NSSet的區(qū)別? NSArray內(nèi)存中存儲(chǔ)地址連續(xù)广辰,而NSSet不連續(xù) NSSet效率高,內(nèi)...
    小緈福閱讀 4,150評(píng)論 1 29
  • map 舉例說明主之,比如我們有一個(gè)函數(shù)f(x)=x2择吊,要把這個(gè)函數(shù)作用在一個(gè)數(shù)組[1, 2, 3, 4, 5, 6,...
    wit92閱讀 131評(píng)論 0 0