0

0

Angular 中基于唯一标识符对比并过滤主数组中的重复对象

霞舞

霞舞

发布时间:2026-02-13 18:25:01

|

691人浏览过

|

来源于php中文网

原创

Angular 中基于唯一标识符对比并过滤主数组中的重复对象

本文介绍如何在 angular 应用中高效比较两个结构不一致的对象数组,依据 `uniqueid` 或 `userid/id` 等关键字段识别并移除主数组中与第二数组存在逻辑重复的项,返回精简后的纯净数据集。

在 Angular(或通用 TypeScript)开发中,常需对来源不同、结构不一的数组进行逻辑去重——例如从后端获取的主数据列表(含丰富嵌套字段)需剔除已被另一配置列表标记为“已禁用”或“待移除”的条目。本例中,mainArray 包含多个复杂对象(含 uniqueId、userId、嵌套 source 和 headers),而 secondArray 是扁平化管理对象(含 UniqueId、Id、Enable 等字段),二者无直接类型对应,但存在业务层面的关联关系:若 mainArray 中某对象的 uniqueId 与 secondArray 中任一对象的 UniqueId 相同,或其 userId 与 secondArray 中某对象的 Id 相同,则该主对象应被过滤掉

以下是一个健壮、可复用的 TypeScript 工具函数实现:

function filterOutDuplicates(
  mainArray: any[],
  secondArray: any[]
): any[] {
  return mainArray.filter((item) => {
    // 跳过空/无效项
    if (!item) return false;

    // 条件1:检查 uniqueId 是否存在于 secondArray.UniqueId 中
    const hasMatchingUniqueId = item.uniqueId && 
      secondArray.some(secondItem => 
        secondItem.UniqueId === item.uniqueId
      );

    // 条件2:检查 userId 是否存在于 secondArray.Id 中(注意字段名大小写差异)
    const hasMatchingUserId = item.userId && 
      secondArray.some(secondItem => 
        secondItem.Id === item.userId
      );

    // 仅当两项均不匹配时保留该主对象(即:无重复才保留)
    return !(hasMatchingUniqueId || hasMatchingUserId);
  });
}

使用示例:

Lemonaid
Lemonaid

AI音乐生成工具,在音乐领域掀起人工智能革命

下载
const mainData = [
  { "userId": 8, "name": "Adfgh", "uniqueId": "rthj", /* ... */ },
  { "userId": 8, "name": "FGHJKNJKN", "uniqueId": "etjhjub", /* ... */ },
  { "customerId": 8, "name": "name", "uniqueId": "remove", /* ... */ },
  // ... 其他项
];

const configData = [
  { "Id": 98, "UniqueId": "remove", "Enable": false },
  { "Id": 154, "UniqueId": "NEO-TEST", "Enable": false }
];

const cleanedData = filterOutDuplicates(mainData, configData);
console.log(cleanedData); // 输出不含 uniqueId === "remove" 的三项

⚠️ 关键注意事项:

  • 字段名大小写敏感:secondArray 中为 UniqueId 和 Id(首字母大写),而 mainArray 中为 uniqueId 和 userId(小驼峰)。代码中已显式处理,切勿直接使用 === 比较未标准化的键名。
  • 空值防御:函数主动跳过 null / undefined 的 item,避免运行时错误;同时对 item.uniqueId 和 item.userId 做真值判断,防止 0、"" 等 falsy 值误判。
  • 性能考量:对中等规模数组( 索引:
    const uniqueIdSet = new Set(secondArray.map(i => i.UniqueId));
    const idSet = new Set(secondArray.map(i => i.Id));
    // 后续用 uniqueIdSet.has(item.uniqueId) 替代 some(),时间复杂度从 O(n²) 降至 O(n)
  • Angular 环境集成:可将此函数封装为独立工具服务(如 DataFilterService),或作为纯函数置于 utils/ 目录下,在组件或 Effect 中按需调用,保持逻辑解耦。

总结而言,该方案不依赖外部库(如 Lodash),完全基于原生 JavaScript/TypeScript 方法,语义清晰、易于测试与维护,精准满足跨结构数组的业务级去重需求——核心在于明确“什么是重复”,而非追求字面 JSON 相等。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

8

2026.02.13

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

709

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

706

2024.03.01

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

15

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号