reduce的高级用法的疑惑

发布于 2022-09-11 22:09:07 字数 563 浏览 10 评论 0

1.计算数组中每个元素出现的次数

let names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];

let nameNum = names.reduce((pre,cur)=>{
  if(cur in pre){
    pre[cur]++
  }else{
    pre[cur] = 1 
  }
  return pre
},{})
console.log(nameNum); //{Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}

2.数组去重

let arr = [1,2,3,4,4,1]
let newArr = arr.reduce((pre,cur)=>{
    if(!pre.includes(cur)){
      return pre.concat(cur)
    }else{
      return pre
    }
},[])
console.log(newArr);// [1, 2, 3, 4]

上面第二个参数是空对象,空数组,这个怎么理解,谢谢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

往事随风而去 2022-09-18 22:09:08

这个是个默认值,作为第一次调用第一个参数callback时的pre,往后的pre值即为callback上一次调用的返回值。

养猫人 2022-09-18 22:09:08

reduce/reduceRight是累加器,第一个参数为回调函数,第二个参数为初始值。
通过第一个参数回调函数对初始值进行累加,

回调函数接收4个参数:

  1. Accumulator (acc) (累计器)
  2. Current Value (cur) (当前值)
  3. Current Index (idx) (当前索引)
  4. Source Array (src) (源数组)

例子

['a', 'b'].reduce((pre, cur, index) => { 
    pre[index] = cur; 
    return pre; 
}, {});
// {0: "a", 1: "b"}

参数链接: https://developer.mozilla.org...

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文