当前位置:网站首页 > 技术博客 > 正文

数组的reduce方法是怎么用的

1.定义

reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

reduce() 可以作为一个高阶函数,用于函数的 compose。

注意: reduce() 对于空数组是不会执行回调函数的。

语法这个方法可以接收两个参数:

要执行的函数,要执行的函数中也可以传入参数,如下

prev:上次调用函数的返回值

cur:当前元素

index:当前元素索引

arr:被遍历的数组

函数迭代的初始值

array.reduce(function(prev, currentValue, currentIndex, arr), initValue)

2.应用

不传入函数迭代的初始值
const arr = [11, 22, 33, 44] const sum = arr.reduce((prev, cur, index) => { console.log(prev, cur, index); return prev + cur }) console.log('sum:', sum); 

控制台打印
在这里插入图片描述
打印结果可以看到, reduce 就是对 arr 从左到右进行累加求和, 如果没有传入函数迭代的初始值, 初始值默认是数组第一位 , prev 就是计算结束后的返回值。

传入函数迭代的初始值
const arr = [11, 22, 33, 44] const sum = arr.reduce((prev, cur, index) => { console.log(prev, cur, index); return prev + cur }, 10) console.log('sum:', sum); 

控制台打印
在这里插入图片描述
打印结果可以看到,我们传入函数迭代的初始值之后,也就是让 prev 从10开始累加,然后接着迭代累加 prev 。

除了平时我们可以用它去求一个数组的和,又或者是乘积,我们还可以拿他去做很多很多的事情,比如 计算数组中每个元素出现的次数,数组去重,扁平数组等等。

计算数组中每个元素出现的次数
const arr = ['张三', '李四', '张三', '王五', '赵六', '王五', '张三'] const obj = arr.reduce((prev, cur) => { console.log(prev, cur); if (cur in prev) { prev[cur] += 1 } else { prev[cur] = 1 } return prev }, {}) console.log(obj); 

控制台打印
在这里插入图片描述

数组去重
const arr = ['张三', '李四', '张三', '王五', '赵六', '王五', '张三'] const newArr = arr.reduce((prev, cur) => { console.log(prev, cur); if (!prev.includes(cur)) { prev.push(cur) } return prev }, []) console.log(newArr); 

控制台打印
在这里插入图片描述

扁平化数组
const arr = [ { label: '水果', children: [ { label: '香蕉' }, { label: '橘子' } ] }, { label: '蔬菜', children: [ { label: '西红柿' }, { label: '白菜' } ] }, { label: '小猫' }, { label: '小狗' } ] const func = (res) => res.reduce((prev, cur) => { console.log(prev, cur) return prev.concat(Array.isArray(cur.children) ? func(cur.children) : cur) }, []) console.log(func(arr)) 

控制台打印
在这里插入图片描述

  • 上一篇: 小红书数据分析
  • 下一篇: hive调整map数
  • 版权声明


    相关文章:

  • 小红书数据分析2024-10-22 22:30:00
  • 小红书小程序爬虫2024-10-22 22:30:00
  • python爬取小红书2024-10-22 22:30:00
  • 小红书出现验证滑块验证不好用了怎么办2024-10-22 22:30:00
  • java程序员要掌握什么2024-10-22 22:30:00
  • hive调整map数2024-10-22 22:30:00
  • js中reduce用法2024-10-22 22:30:00
  • HIVE中的四种排序方式是什么,简述其特点2024-10-22 22:30:00
  • vue2 provide inject用法2024-10-22 22:30:00
  • python 小红书爬虫2024-10-22 22:30:00