前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js 数组里面去重对象的方法

js 数组里面去重对象的方法

作者头像
江咏之
发布2022-06-17 13:35:28
2.1K0
发布2022-06-17 13:35:28
举报
文章被收录于专栏:技术社区技术社区

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

代码语言:javascript
复制
 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
            }];

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

代码语言:javascript
复制
  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方法,访问遍历数组,其也是借助访问对象属性方法

代码语言:javascript
复制
			var obj = {};
            points = points.reduce(function(item, next) {
                obj[next.lat] ? '' : obj[next.lat] = true && item.push(next);
                return item;
            }, []);
             console.log(points)  ;  
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-12-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档