JavaScript JSON数组根据id去重

博客介绍了在JavaScript中处理JSON数组重复数据的方法。一是定义拥有重复数据的JSON数组,编写方法过滤重复数据;二是在添加数据时,编写函数判断若有重复则不添加,以此完成重复数据的处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们先来定义一个拥有重复数据的json数组

var arr = [{
	id: '1',
	 name: '小明'
}, {
	 id: '2',
	 name: '小昭'
}, {
	 id: '2',
	 name: '小昭'
}, {
	 id: '3',
	 name: '小美'
}, {
	id: '3',
	name: '小美'
}];

可以看到 我们这 二三条是重复的 id都为2 四五条又是重复的 id都为3

那么 我们写一个方法来过滤掉重复的数据

function filterArray(ArrObj){
	var obj = {};
	 ArrObj = ArrObj.reduce(function (item, next) {
	   obj[next.id] ? '' : obj[next.id] = true && item.push(next);
	   return item;
	 }, []);
	 return ArrObj
}

然后我们来调用这个方法

console.log(filterArray(arr))

运行结果如下
在这里插入图片描述
此时我们就完成了重复数据的过滤

或者是在添加时 判断如果有重复的就不添加了 写一个函数演示

function filterArray(ArrObj){
   var obj = [];
  ArrObj.map(item =>{
    if (!obj.some(e => e.id == item.id)) {
      obj.push(item);
    }
  })
  return obj
}

然后调用函数

console.log(filterArray(arr));

在这里插入图片描述
也没有任何问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值