欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js利用reduce方法讓你的代碼更加優(yōu)雅

 更新時(shí)間:2021年08月29日 11:01:46   作者:_island  
一直以來(lái)都在函數(shù)式編程的大門(mén)之外徘徊,要入門(mén)的話首先得熟悉各種高階函數(shù),數(shù)組的reduce方法就是其中之一,這篇文章主要給大家介紹了關(guān)于js利用reduce方法讓你的代碼更加優(yōu)雅的相關(guān)資料,需要的朋友可以參考下

前言

在實(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)文章

最新評(píng)論