使用reduce方法对数组进行去重

语法:array.reduce(function(total, currentValue, currentIndex, arr), initialValue)

total    必需。初始值, 或者计算结束后的返回值。
currentValue   必需。当前元素
currentIndex   可选。当前元素的索引
arr    可选。当前元素所属的数组对象。
initialValue   可选。传递给函数的初始值
 

题目1:

["b", "c","b", "c","a", "b", "c"] 统计每个元素出现的次数,结果是: {a:1,b: 3, c: 3}

  reduce()方法

const arr = ["b", "c","b", "c","a", "b", "c"]

const obj= arr.reduce((acc,cur)=>{
  acc[cur]?acc[cur]++:acc[cur]=1
  return acc
},{})

console.log(obj)  // ==> {a:1, b: 3, c:  3}

霸道写法: 

 const arr = ["b", "c","b", "c","a", "b", "c"]

// 转换成一行
 const obj=arr.reduce((sum,item)=>(sum[item]?sum[item]++:(sum[item]=1),sum),{}) 

 console.log(obj)  // ==> {a:1, b: 3, c:  3}

题目二:

const arr = [{ label: '男', value: 1 }, { label: '女', value: 0 }]

reduce()方法

const arr = [{ label: '男', value: 1 }, { label: '女', value: 0 }]

const obj= arr.reduce((cur,item)=>{
   cur[item.label]=item.value
   return cur
 },{})

console.log(obj) //  {男: 1, 女: 0}

霸道写法: 

const arr = [{ label: '男', value: 1 }, { label: '女', value: 0 }]

const obj= arr.reduce((cur,item)=>(cur[item.label]=item.value,cur),{})

console.log(obj) //  {'1': '男',  '0': '女'}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值