专栏首页前端儿JS 数组去重(数组元素是对象的情况)

JS 数组去重(数组元素是对象的情况)

js数组去重有经典的 几种方法

但当数组元素是对象时,就不能简单地比较了,需要以某种方式遍历各值再判断是否已出现。

因为:

1.如果是哈希判断法,对象作哈希表的下标,就会自动转换成字符型类型,从而导致所有元素都相等,这时判断方法不再有意义。一般最后数组就只剩一个

2.如果是直接比较法,则因为对象在内存中是按引用访问的,属性值相同的对象也不会相等,简单的直接判断不再有意义。一般最后数组还是原样

所以就需要进行值的比较

当然了,也可以换着法来将相应对象转为字符串(不是默认的那种[object Object])

举个例子:

var array = [
    {a:1,b:2,c:3,d:4},
    {a:11,b:22,c:333,d:44},
    {a:111,b:222,c:333,d:444},
    {a:11,b:22,c:33,d:44},
    {a:11,b:22,c:33,d:444}
    ];

假如需要按照属性a,b为数组进行去重

那么最后将得到

array = [
    {a:1,b:2,c:3,d:4},
    {a:11,b:22,c:333,d:44},
    {a:111,b:222,c:333,d:444}
    ];
//将对象元素转换成字符串以作比较
function obj2key(obj, keys){
    var n = keys.length,
        key = [];
    while(n--){
        key.push(obj[keys[n]]);
    }
    return key.join('|');
}
//去重操作
function uniqeByKeys(array,keys){
    var arr = [];
    var hash = {};
    for (var i = 0, j = array.length; i < j; i++) {
        var k = obj2key(array[i], keys);
        if (!(k in hash)) {
            hash[k] = true;
            arr .push(array[i]);
        }
    }
    return arr ;
}
//进行去重
var arr = uniqeByKeys(array,['a','b']);

这种方式暂时还可以,当然了如果出现那种属性和值组合正好有出现xx相同的那就xx了

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • CSS布局 -- 左右定宽,中间自适应

    左右设置绝对定位,定宽,中间设置margin-left  margin-right

    书童小二
  • 教你如何在React及Redux项目中进行服务端渲染

    使用 redux-saga 处理异步action,使用 express 处理页面渲染

    书童小二
  • 前端读取Excel报表文件

    在实际开发中,经常会遇到导入Excel文件的需求,有的产品人想法更多,想要在前端直接判断文件内容格式是否正确,必填项是否已填写

    书童小二
  • 二叉堆

    在我们用代码实现二叉堆之前,我们先了解一下几个技巧,二叉堆由于采用数组进行存储,所以我们定位一个节点只需要确认该节点在数组中的下表即可。

    shysh95
  • JS数组去重的几种常见方法

    李才哥
  • 003-二维数组的查找

    在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个...

    单车变摩托
  • 基础算法(二)

            上一篇:基础算法(一)         1. 冒泡排序(BubbleSort)         原理:依次比较相邻的两个数,将小数放在前面,大数...

    高爽
  • Swift3中的Array内存地址和关联对象的问题

    xferris
  • shell|数组,忘记写小括号到再次认识数组

    TARGETS=`ps -ef|grep my.py| grep -v "grep"|awk '{print $2}'`

    heidsoft
  • JDK PriorityBlockingQueue remove(Object o) 源码分析

    先知道PriorityBlockingQueue 是利用数组存储二叉堆实现。最小值(最优先)放在queue[0]位置。 //删除某个元素 public bool...

    技术蓝海

扫码关注云+社区

领取腾讯云代金券