JS对象数组去重有哪些常用方法

来源:Python编程网作者:北京GEO公司头衔:草根站长
导读:本期聚焦于小伙伴创作的《JS对象数组去重有哪些常用方法》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《JS对象数组去重有哪些常用方法》有用,将其分享出去将是对创作者最好的鼓励。

JS对象数组去重是前端开发中非常常见的需求,由于对象属于引用类型,直接使用Set或者数组的filter、indexOf方法无法实现去重,需要结合对象的唯一标识属性来处理。常见的去重维度可以是对象的某个唯一id,也可以是多个属性组合后的唯一值。

JS对象数组去重有哪些常用方法

方法一:使用reduce结合Map实现去重

reduce方法可以遍历数组并累积处理结果,配合Map存储已经出现过的唯一标识,能够高效完成去重。Map的查找时间复杂度为O(1),整体去重性能较好。

// 待去重的对象数组,按id去重
const arr = [
  { id: 1, name: '张三' },
  { id: 2, name: '李四' },
  { id: 1, name: '张三' },
  { id: 3, name: '王五' }
];

const result = arr.reduce((map, current) => {
  // 如果Map中不存在当前id,就存入Map
  if (!map.has(current.id)) {
    map.set(current.id, current);
  }
  return map;
}, new Map());

// 将Map的值转为数组
const uniqueArr = Array.from(result.values());
console.log(uniqueArr);
// 输出:[{ id: 1, name: '张三' }, { id: 2, name: '李四' }, { id: 3, name: '王五' }]

方法二:使用Set结合JSON.stringify去重

如果需要按照对象的完整内容去重,而不是某个单一属性,可以先将对象转为JSON字符串,再用Set存储字符串,最后转回对象数组。不过这种方法要求对象的属性顺序一致,否则相同内容的对象可能因为属性顺序不同被判定为不同。

const arr = [
  { id: 1, name: '张三', age: 20 },
  { id: 2, name: '李四', age: 22 },
  { id: 1, name: '张三', age: 20 },
  { age: 20, id: 1, name: '张三' } // 属性顺序不同,JSON字符串不同,无法去重
];

// 先转JSON字符串再用Set去重
const strSet = new Set(arr.map(item => JSON.stringify(item)));
// 转回对象数组
const uniqueArr = Array.from(strSet).map(item => JSON.parse(item));
console.log(uniqueArr);

方法三:使用filter结合findIndex去重

filter方法可以过滤数组元素,结合findIndex查找当前元素在数组中第一次出现的位置,如果当前索引等于第一次出现的索引,说明是首次出现,保留该元素即可。这种方法逻辑比较直观,但是findIndex每次都需要遍历查找,性能比reduce加Map的方式稍差。

const arr = [
  { id: 1, name: '张三' },
  { id: 2, name: '李四' },
  { id: 1, name: '张三' },
  { id: 3, name: '王五' }
];

const uniqueArr = arr.filter((item, index) => {
  // 查找当前id第一次出现的索引
  const firstIndex = arr.findIndex(el => el.id === item.id);
  // 如果当前索引等于第一次出现的索引,保留该元素
  return index === firstIndex;
});

console.log(uniqueArr);

不同方法的选择建议

如果去重维度是对象的某个唯一属性,优先选择reduce结合Map的方式,性能最优;如果需要按对象完整内容去重,且能保证属性顺序一致,可以使用Set结合JSON.stringify的方式;如果对性能要求不高,希望逻辑更简单直观,也可以选择filter结合findIndex的方式。

去重方法适用场景性能
reduce + Map按单一属性去重
Set + JSON.stringify按对象完整内容去重,属性顺序一致
filter + findIndex简单场景,对性能要求不高

JS对象数组去重reduceSetMap修改时间:2026-06-17 12:27:26

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。