js利用reduce方法讓你的代碼更加優(yōu)雅
前言
在實際項目中,最常見可能是在計算、循環(huán)邏輯方面的處理,可以使用數(shù)組中reduce方法也可以解決很多的問題,使得你的代碼風(fēng)格更加優(yōu)雅!
reduce語法
arr.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
參數(shù)說明
reducer函數(shù)需要接收4個參數(shù)分別是
callback
- Accumulator
- 累計器累計回調(diào)的返回值; 它是上一次調(diào)用回調(diào)時返回的累積值,或initialValue。
- Current Value
- 數(shù)組中正在處理的元素。
- Current Index
- 這是一個可選參數(shù),數(shù)組中正在處理的當前元素的索引。 如果提供了initialValue,則起始索引號為0,否則從索引1起始。
- Source Array
- 這是一個可選參數(shù),調(diào)用reduce()的數(shù)組
initialValue
- 作為第一次調(diào)用 callback函數(shù)時的第一個參數(shù)的值。 如果沒有提供初始值,則將使用數(shù)組中的第一個元素。 在沒有初始值的空數(shù)組上調(diào)用 reduce 將報錯。
返回值
- 函數(shù)累計處理的結(jié)果
一些reduce常用方法
數(shù)組里所有元素的和
const arr = [1, 2, 3, 4]; const result = arr.reduce((acc, cur) => acc + cur) console.log(result) // 10
計算數(shù)組中每個元素出現(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
這種方式實際上處理的是promise的value,將上一個promise的value作為下一個promise的value進行處理。
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);
})
最后
本文分享了一些在日常開發(fā)中比較常用的一些reduce處理方法,你可以直接拿到你的項目中使用,也可以進行二次封裝。
到此這篇關(guān)于js利用reduce方法讓你的代碼更加優(yōu)雅的文章就介紹到這了,更多相關(guān)js reduce方法讓代碼優(yōu)雅內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實現(xiàn)保留n位小數(shù)的四舍五入問題示例
這篇文章主要介紹了JS實現(xiàn)保留n位小數(shù)的四舍五入問題,結(jié)合完整實例形式分析了javascript針對小數(shù)四舍五入操作技巧,需要的朋友可以參考下2016-08-08
js實現(xiàn)顯示當前狀態(tài)的導(dǎo)航效果代碼
這篇文章主要介紹了js實現(xiàn)顯示當前狀態(tài)的導(dǎo)航效果代碼,涉及javascript通過鼠標點擊事件動態(tài)改變頁面元素屬性的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2015-08-08
Javascript 構(gòu)造函數(shù),公有,私有特權(quán)和靜態(tài)成員定義方法
其中公有方法聲明的部分采用的兩種方式,在實際應(yīng)用中一般采取一種方式就可以了,如果兩種方式都要采用的話,應(yīng)注意順序,防止前面寫的方法被清空或覆蓋。2009-11-11
微信小程序非跳轉(zhuǎn)式組件授權(quán)登錄的方法示例
這篇文章主要介紹了微信小程序非跳轉(zhuǎn)式組件授權(quán)登錄的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05

