中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js中如何使用reduce

發布時間:2021-08-30 09:16:35 來源:億速云 閱讀:123 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關js中如何使用reduce,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

reduce語法

arr.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])

參數說明

reducer函數需要接收4個參數分別是

callback

  • Accumulator

    • 累計器累計回調的返回值; 它是上一次調用回調時返回的累積值,或initialValue。

  • Current Value

    • 數組中正在處理的元素。

  • Current Index

    • 這是一個可選參數,數組中正在處理的當前元素的索引。 如果提供了initialValue,則起始索引號為0,否則從索引1起始。

  • Source Array

    • 這是一個可選參數,調用reduce()的數組

initialValue

  • 作為第一次調用 callback函數時的第一個參數的值。 如果沒有提供初始值,則將使用數組中的第一個元素。 在沒有初始值的空數組上調用 reduce 將報錯。

返回值

  • 函數累計處理的結果

一些reduce常用方法

數組里所有元素的和

const arr = [1, 2, 3, 4];
const result = arr.reduce((acc, cur) => acc + cur)

console.log(result) // 10

計算數組中每個元素出現的次數

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}

扁平化數組

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"]

數組去重

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]

求數組中最大值

const arr = [1, 2, 3, 5, 1]
let result = arr.reduce((acc, cur) => Math.max(acc, cur))

console.log(result)

按照順序調用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);
})

關于“js中如何使用reduce”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兰考县| 屯昌县| 西平县| 乐都县| 博湖县| 班戈县| 普陀区| 伊吾县| 五大连池市| 金华市| 乐至县| 桦南县| 苍梧县| 靖州| 台安县| 文昌市| 恭城| 顺平县| 双鸭山市| 砀山县| 淅川县| 应城市| 治县。| 常宁市| 盱眙县| 土默特右旗| 平遥县| 涿鹿县| 来宾市| 夏津县| 垣曲县| 嵩明县| 沾化县| 通海县| 新郑市| 泽普县| 巨野县| 稻城县| 清流县| 蕉岭县| 台湾省|