js利用reduce方法讓你的代碼更加優(yōu)雅
前言
在實(shí)際項(xiàng)目中,最常見(jiàn)可能是在計(jì)算、循環(huán)邏輯方面的處理,可以使用數(shù)組中reduce方法也可以解決很多的問(wèn)題,使得你的代碼風(fēng)格更加優(yōu)雅!
reduce語(yǔ)法
arr.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
參數(shù)說(shuō)明
reducer函數(shù)需要接收4個(gè)參數(shù)分別是
callback
- Accumulator
- 累計(jì)器累計(jì)回調(diào)的返回值; 它是上一次調(diào)用回調(diào)時(shí)返回的累積值,或initialValue。
- Current Value
- 數(shù)組中正在處理的元素。
- Current Index
- 這是一個(gè)可選參數(shù),數(shù)組中正在處理的當(dāng)前元素的索引。 如果提供了initialValue,則起始索引號(hào)為0,否則從索引1起始。
- Source Array
- 這是一個(gè)可選參數(shù),調(diào)用reduce()的數(shù)組
initialValue
- 作為第一次調(diào)用 callback函數(shù)時(shí)的第一個(gè)參數(shù)的值。 如果沒(méi)有提供初始值,則將使用數(shù)組中的第一個(gè)元素。 在沒(méi)有初始值的空數(shù)組上調(diào)用 reduce 將報(bào)錯(cuò)。
返回值
- 函數(shù)累計(jì)處理的結(jié)果
一些reduce常用方法
數(shù)組里所有元素的和
const arr = [1, 2, 3, 4]; const result = arr.reduce((acc, cur) => acc + cur) console.log(result) // 10
計(jì)算數(shù)組中每個(gè)元素出現(xiàn)的次數(shù)
const nums = ['1', '1', '1', '2', '3']; const countednums = nums.reduce((acc, cur) => { if (cur in acc) { acc[cur]++; } else { acc[cur] = 1; } return acc; }, {}); console.log(countednums); // {1: 3, 2: 1, 3: 1}
扁平化數(shù)組
const arr = [['a', 'b'], ['b', 'c'], ['d', 'e']] const flatten = arr => { return arr.reduce((acc, cur) => { return acc.concat(cur) }, []) } console.log(flatten(arr)); // ["a", "b", "b", "c", "d", "e"]
數(shù)組去重
const arr = [22,341,124,54,4,21,4,4,1,4,4]; const result = arr.sort().reduce((acc, cur) => { if(acc.length === 0 || acc[acc.length-1] !== cur) { acc.push(cur); } return acc; }, []); console.log(result); // [1, 124, 21, 22, 341, 4, 54]
求數(shù)組中最大值
const arr = [1, 2, 3, 5, 1] let result = arr.reduce((acc, cur) => Math.max(acc, cur)) console.log(result)
按照順序調(diào)用promise
這種方式實(shí)際上處理的是promise的value,將上一個(gè)promise的value作為下一個(gè)promise的value進(jìn)行處理。
const prom1 = a => { return new Promise((resolve => { resolve(a) })) } const prom2 = a => { return new Promise((resolve => { resolve(a * 2) })) } const prom3 = a => { return new Promise((resolve => { resolve(a * 3) })) } const arr = [prom1, prom2, prom3] const result = arr.reduce((all, current) => { return all.then(current) }, Promise.resolve(10)) result.then(res => { console.log(res); })
最后
本文分享了一些在日常開(kāi)發(fā)中比較常用的一些reduce處理方法,你可以直接拿到你的項(xiàng)目中使用,也可以進(jìn)行二次封裝。
到此這篇關(guān)于js利用reduce方法讓你的代碼更加優(yōu)雅的文章就介紹到這了,更多相關(guān)js reduce方法讓代碼優(yōu)雅內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript常見(jiàn)數(shù)據(jù)驗(yàn)證插件大全
這篇文章主要介紹了javascript常見(jiàn)數(shù)據(jù)驗(yàn)證插件大全,需要的朋友可以參考下2015-08-08Javascript計(jì)算二維數(shù)組重復(fù)值示例代碼
這篇文章主要給大家介紹了利用Javascript計(jì)算二維數(shù)組重復(fù)值的方法,文中給出了詳細(xì)的示例代碼,相信對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。2016-12-12JavaScript 限制文本框不可輸入英文單雙引號(hào)的方法
這篇文章主要介紹了JavaScript 限制文本框不可輸入英文單雙引號(hào)的方法的相關(guān)資料,需要的朋友可以參考下2016-12-12微信小程序 scroll-view 水平滾動(dòng)實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了微信小程序 scroll-view 水平滾動(dòng)實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10ES6 Symbol在對(duì)象中的作用實(shí)例分析
這篇文章主要介紹了ES6 Symbol在對(duì)象中的作用,結(jié)合實(shí)例形式分析了ES6 Symbol在對(duì)象中聲明、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2020-06-06你必須了解的JavaScript中的屬性描述對(duì)象詳解(下)
JavaScript提供了一個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu),用來(lái)描述對(duì)象的屬性,控制它的行為,比如該屬性是否可寫(xiě)、可遍歷等等。這個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu)稱為“屬性描述對(duì)象”。本文主要帶大家了解一下JavaScript中你必須了解的屬性描述對(duì)象,需要的可以參考一下2022-12-12JS中圖片緩沖loading技術(shù)的實(shí)例代碼
這篇文章介紹了JS中圖片緩沖loading技術(shù)的實(shí)例代碼,有需要的朋友可以參考一下2013-08-08