单个对象数组去重

// 单个数组对象 去除重复项
      distinctObjArray(array = [], uniqueKey) {
        if (array === null || array.length === 0) return []
        uniqueKey = !uniqueKey ? [] : (Array.isArray(uniqueKey) ? uniqueKey : [uniqueKey])
        uniqueKey = uniqueKey.length === 0 ? Object.keys(array[0]) : uniqueKey
        const uniqueSet = new Set()

        return array.reduce((res, item) => {
          const r = {}
          uniqueKey.forEach(key => { r[key] = item[key] })
          if (!uniqueSet.has(JSON.stringify(r))) {
            res.push(item)
            uniqueSet.add(JSON.stringify(r))
          }
          return res
        }, [])
      }

array 为对象数组 ,uniqueKey为array中的某一属性

TIP:

所传数组不是个空数组

是否有传按需判断的属性值uniqueKey

Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和正常循环遍历该对象时返回的顺序一致 。

// simple array
var arr = ['a', 'b', 'c'];
console.log(Object.keys(arr)); // console: ['0', '1', '2']

// array like object
var obj = { 0: 'a', 1: 'b', 2: 'c' };
console.log(Object.keys(obj)); // console: ['0', '1', '2']

// array like object with random key ordering
var anObj = { 100: 'a', 2: 'b', 7: 'c' };
console.log(Object.keys(anObj)); // console: ['2', '7', '100']

// getFoo is a property which isn't enumerable
var myObj = Object.create({}, {
  getFoo: {
    value: function () { return this.foo; }
  } 
});
myObj.foo = 1;
console.log(Object.keys(myObj)); // console: ['foo']
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值