当前位置: 首页 > news >正文

js 比较两个对象的值,不相等就push对象的key

在JavaScript中,比较两个对象(object)的值并找出不相等的key,可以通过多种方法实现。下面是一些常用的方法:

方法1:使用JSON.stringify

这种方法适用于简单的对象,其中对象的值是基本类型或可以直接序列化为JSON的对象。

function findDifferences(obj1, obj2) {const keys1 = Object.keys(obj1);const keys2 = Object.keys(obj2);const differences = [];// 比较每个keykeys1.forEach(key => {if (obj1[key] !== obj2[key]) {differences.push(key);}});// 检查obj2是否有在obj1中不存在的key,并且这些key的值也不相等(反向检查)keys2.forEach(key => {if (!keys1.includes(key) && obj2[key] !== obj1[key]) {differences.push(key);}});return differences;
}const obj1 = { a: 1, b: 2 };
const obj2 = { a: 1, b: 3 };
console.log(findDifferences(obj1, obj2)); // 输出: ['b']

方法2:递归比较对象(适用于嵌套对象)

如果对象中包含嵌套对象,则需要递归地比较它们的每个属性。

function deepCompare(obj1, obj2) {const keys1 = Object.keys(obj1);const keys2 = Object.keys(obj2);const differences = [];// 比较每个key的值keys1.forEach(key => {if (!obj2.hasOwnProperty(key)) {differences.push(key); // key在obj2中不存在} else if (typeof obj1[key] === 'object' && typeof obj2[key] === 'object') {differences.push(...findDifferences(obj1[key], obj2[key]).map(k => `${key}.${k}`)); // 递归比较并标记路径} else if (obj1[key] !== obj2[key]) {differences.push(key); // 值不相等}});// 检查obj2中是否有在obj1中不存在的key,并且这些key的值也不相等(反向检查)keys2.forEach(key => {if (!keys1.includes(key)) {differences.push(key); // key在obj1中不存在,但可能在obj2中有值,认为是差异}});return differences;
}function findDifferences(obj1, obj2) {return deepCompare(obj1, obj2);
}const obj1 = { a: 1, b: { c: 2, d: 3 } };
const obj2 = { a: 1, b: { c: 2, d: 4 } };
console.log(findDifferences(obj1, obj2)); // 输出: ['b.d']

方法3:使用lodashisEqualomitBy函数(使用第三方外部库)

如果倾向于使用一个成熟的库来处理这类问题,lodash是一个不错的选择。isEqual可以用来深度比较两个对象,而omitBy可以用来过滤掉相等的属性。

const _ = require('lodash'); // 确保已安装lodash库 npm install lodashfunction findDifferences(obj1, obj2) {const diffKeys = _.omitBy(_.merge({}, obj1, obj2), (value, key) => _.isEqual(value, obj1[key])); // 获取不相等的键值对,但不包括相等的键值对。注意:这种方法在某些情况下可能不会完全准确(例如,当对象结构不同时),因为它试图合并两个对象。对于简单的差异检测,你可能需要自定义逻辑来处理嵌套对象的差异。return Object.keys(diffKeys); // 返回所有不相等的键的数组。
}
最后: 

对于嵌套对象的精确比较,可能需要自定义逻辑来处理嵌套结构的不同。例如,可以使用递归方法来精确地比较每个嵌套对象的属性。上面的deepCompare方法就是一个例子。

选择哪种方法取决于具体的开发需求,比如对象的复杂度、是否允许使用外部库等。对于简单的键值对比较,直接使用方法一,复杂一些的,可以参考方法二和方法三。

http://www.lqws.cn/news/160021.html

相关文章:

  • 平台升级:新功能与新模型震撼登场!
  • 华硕电脑,全新的超频方式,无需进入BIOS
  • uniapp实现的简约美观的星级评分组件
  • rust或tauri项目执行命令的时候,cmd窗口也会弹出显示解决方法
  • OpenCV 图像通道的分离与合并
  • Windows+Cmake编译Opencv-python
  • 【数据结构】树形结构--二叉树(二)
  • docker 搭建php 开发环境 添加扩展redis、swoole、xdebug(2)
  • Palo Alto Networks Expedition存在命令注入漏洞(CVE-2025-0107)
  • nodejs里面的http模块介绍和使用
  • Ubuntu系统配置C++的boost库(含filesystem模块)的方法
  • ASP.NET Core使用Quartz部署到IIS资源自动被回收解决方案
  • 【.net core】.KMZ文件解压为.KML文件并解析为GEOJSON坐标数据集。附KML处理多线(LineString)闭环问题
  • 37.第二阶段x64游戏实战-封包-寻找Socket套接字
  • 最新研究揭示云端大语言模型防护机制的成效与缺陷
  • 【.net core】天地图坐标转换为高德地图坐标(WGS84 坐标转 GCJ02 坐标)
  • SpringBoot项目移动之后无法运行
  • vue-18(使用 Vuex 插件实现高级功能)
  • 03.01、三合一
  • MyBatis-Plus深度全解:从入门到企业级实战
  • 【Elasticsearch】Elasticsearch 核心技术(二):映射
  • 力扣100题之128. 最长连续序列
  • el-tabs 切换时数据不更新的问题
  • 6月5日day45
  • 群晖NAS如何在虚拟机创建飞牛NAS
  • 基于STM32的DS18B20温度远程监测LCD1602显示
  • STL优先级队列的比较函数与大堆小堆的关系
  • LoRA:大模型高效微调的低秩之道——原理解析与技术实现
  • 代码随想录算法训练营第九天| 151.翻转字符串里的单词、55.右旋转字符串 、字符串总结
  • 25.6.5学习总结