js中数组对象去重的方法

js中数组对象去重的方法

    今天在进行百度地图开发时,遇到多个重复的点位,需要将重复的点位进行过滤,正常的数组我们通常都能找到方法进行解决,但对对象数组进行去重处理,有点蒙圈,下面我们就进一步研究

 var points = [{
                lat: 22.687,
                lng: 114.014
            }, {
                lat: 22.687,
                lng: 112.004
            }, {
                lat: 22.837,
                lng: 114.014
            },{
                lat: 26.687,
                lng: 115.014
            },{
                lat: 22.687,
                lng: 115.014
            },{
                lat: 22.687,
                lng: 114.014
            }];

    方法一:
我们可以借助对象访问属性的方法,判断属性是否存在,如果已存在则进行过滤

  var result = [];
            var obj = {};
            for(var i =0; i<points.length; i++){
                if(!obj[points[i].lat]){
                    result.push(points[i]);
                    obj[points[i].lat] = true;
                }
            }
       console.log(result)  ;  

结果为:
在这里插入图片描述
    方法二:
我们可以借助数组中reduce方法,访问遍历数组,其也是借助访问对象属性方法

			var obj = {};
            points = points.reduce(function(item, next) {
                obj[next.lat] ? '' : obj[next.lat] = true && item.push(next);
                return item;
            }, []);
             console.log(points)  ;  

结果为:
在这里插入图片描述
    对比上述两种方法,其产生的过滤结果一样

参考来源:
https://www.jb51.net/article/154887.htm

  • 3
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值