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

JavaScript中判断两个对象是否相同(所有属性的值是否都相同)

在JavaScript中,判断两个对象的所有属性是否相同(包括嵌套对象)需要深度比较(deep comparison)。以下是几种实现方法:


方法1:简易深度比较(不考虑循环引用、Symbol和特殊对象)

javascript

复制

下载

function deepEqual(obj1, obj2) {// 基本类型直接比较if (obj1 === obj2) return true;// 检查是否为对象且非nullif (typeof obj1 !== 'object' || obj1 === null ||typeof obj2 !== 'object' || obj2 === null) {return false;}// 比较构造函数类型if (obj1.constructor !== obj2.constructor) return false;// 获取对象的键(仅自身可枚举属性)const keys1 = Object.keys(obj1);const keys2 = Object.keys(obj2);// 键数量不同则不等if (keys1.length !== keys2.length) return false;// 递归比较每个键的值for (const key of keys1) {if (!keys2.includes(key) || !deepEqual(obj1[key], obj2[key])) {return false;}}return true;
}

方法2:完整深度比较(支持循环引用、Symbol和特殊对象)

javascript

复制

下载

function deepEqual(obj1, obj2, visited = new WeakMap()) {// 基本类型直接比较if (obj1 === obj2) return true;// 检查是否为对象且非nullif (typeof obj1 !== 'object' || obj1 === null ||typeof obj2 !== 'object' || obj2 === null) {return false;}// 处理循环引用if (visited.has(obj1) {return visited.get(obj1) === obj2;}visited.set(obj1, obj2);// 比较构造函数类型if (obj1.constructor !== obj2.constructor) return false;// 特殊对象处理if (obj1 instanceof Date) return obj1.getTime() === obj2.getTime();if (obj1 instanceof RegExp) return obj1.toString() === obj2.toString();// 获取所有键(包括Symbol和自身可枚举属性)const keys1 = Reflect.ownKeys(obj1);const keys2 = Reflect.ownKeys(obj2);// 键数量不同则不等if (keys1.length !== keys2.length) return false;// 递归比较每个键的值for (const key of keys1) {if (!Reflect.has(obj2, key) ||!deepEqual(obj1[key], obj2[key], visited)) {return false;}}return true;
}

关键点说明

  1. 深度递归

    • 逐层比较嵌套对象的属性值。

    • 使用递归处理嵌套结构。

  2. 循环引用处理

    • 通过 WeakMap 记录已比较对象,避免无限递归。

    • 当检测到循环引用时直接比较引用是否相同。

  3. 特殊对象支持

    • Date:比较时间戳。

    • RegExp:比较正则表达式的字符串形式。

    • Array:自动支持(数组也是对象)。

  4. 键类型支持

    • 使用 Reflect.ownKeys() 获取所有自身键(包括Symbol)。

    • 使用 Object.keys() 仅获取可枚举字符串键(简易版)。

  5. 严格检查

    • 比较构造函数确保类型一致(如 Array vs Object)。

    • 键数量不等时快速失败。


使用示例

javascript

复制

下载

const objA = { a: 1, b: { c: 2 }, d: [3, 4] };
const objB = { a: 1, b: { c: 2 }, d: [3, 4] };
const objC = { a: 1, b: { c: 99 } };console.log(deepEqual(objA, objB)); // true
console.log(deepEqual(objA, objC)); // false

注意事项

  • 性能:深度比较可能较慢,避免在大型对象上使用。

  • 特殊对象:如需支持 Set/Map 等,需额外扩展。

  • 函数属性:函数按引用比较(通常不比较函数体)。

  • 库推荐:复杂场景建议使用 Lodash 的 _.isEqual()

javascript

复制

下载

// 使用 Lodash 的深度比较
import _ from 'lodash';
console.log(_.isEqual(objA, objB)); // true

相关文章:

  • Spring BeanPostProcessor
  • 《小明的一站式套餐服务平台》
  • 猎板硬金镀层厚度:高频通信领域的性能分水岭
  • Java面试高频核心内容
  • JAVASE:面向对象
  • Pendulum:优雅处理 Python 中的日期与时间
  • CET6 仔细阅读 24年12月第三套-C1 恐惧这一块
  • SAFe/LeSS/DAD等框架的核心适用场景如何选择?
  • 学习笔记(24): 机器学习之数据预处理Pandas和转换成张量格式[2]
  • 开发源码搭建一码双端应用分发平台教程:逐步分析注意事项
  • 激活函数和归一化、正则化
  • return this;返回的是谁
  • Odoo 18 定期发送电子邮件报告(如KPI)配置指南
  • vivo y300pro 无法连接adb
  • C++语法系列之IO流
  • Linux网络协议栈:从Socket到网卡的星辰大海
  • python实现合并多个dot文件
  • 【AI系列】DPO 与 PPO 的比较与分析
  • 标准IO及相关函数介绍
  • Efficient RAW Image Deblurring with Adaptive Frequency Modulation
  • wordpress 导航网站模板下载/新媒体运营是做什么
  • 搭建正规网站/公司网站建设服务机构
  • seo整站优化哪家好/想建立自己的网站怎么建立
  • 广州网站优化注意事项/网络推广工作
  • b2b免费信息发布网站/seo快排优化
  • 潍坊市网站制作/怎么提交百度收录