js数组去重

1、使用reduce

定义一个obj,用reduce遍历数组,如果obj里面存在当前项的id,则不做操作,如果obj存在当前项的id,则obj添加当前id数据,并且push到reduce的累加项里。最后return preArr

// 数组对象去重
function unique(arr) {
  let obj = {}
  return arr.reduce((preArr,item) => {
    obj[item.id] ? '' : obj[item.id] = true && preArr.push(item)
    return preArr;
  },[])
}

let res = unique([{"id":1,"name":"张三"},{"id":2,"name":"李四"},{"id":3,"name":"王五"},{"id":2,"name":"张三"}])
console.log('去重后的数组',res); // [{"id":1,"name":"张三"},{"id":2,"name":"李四"},{"id":3,"name":"王五"}]

2、使用map和filter

判断map对象是否有id和name,如果有则返回false,被filter过滤掉。如果没有则map.set进去返回true被filter捕获

function unique(arr) {
  const map = new Map
  return arr.filter(item => !map.has(item.id) && !map.has(item.name) && map.set(item.id,true)  && map.set(item.name,true))
}

let arr = [
  {"id":1,"name":"张三","mobile": '12345'},
  {"id":2,"name":"李四","mobile": '45678'},
  {"id":3,"name":"王五","mobile": '75351'},
  {"id":1,"name":"张三","mobile": '15155'}
]

console.log('去重后的对象',unique(arr)); // [{"id":1,"name":"张三","mobile": '12345'},{"id":2,"name":"李四","mobile": '45678'},{"id":3,"name":"王五","mobile": '75351'}]

3、使用forEach

function unique(arr) {
  let obj = {}
  let resArr = []
  arr.forEach(item => {
    if(!obj[item.id]) {
      obj[item.id] = true && resArr.push(item)
    }
  })
  return resArr
}

let arr = [
  {"id":1,"name":"张三","mobile": '12345'},
  {"id":2,"name":"李四","mobile": '45678'},
  {"id":3,"name":"王五","mobile": '75351'},
  {"id":1,"name":"张三","mobile": '15155'}
]

console.log('去重后的对象',unique(arr)); // [{"id":1,"name":"张三","mobile": '12345'},{"id":2,"name":"李四","mobile": '45678'},{"id":3,"name":"王五","mobile": '75351'}]

4、基本数据类型的数组去重

function unique(arr) {
  // return [...new Set(arr)]
  return Array.from(new Set(arr))
}

let arr = [1,2,5,7,4,2,8,7,3,1,4,5,7,4,3,2,5,6,4]
console.log(unique(arr).sort()); // [1, 2, 3, 4, 5, 6, 7, 8]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值