在JS中如何判断两个对象是否相等

yizhihongxing

在JavaScript中,判断两个对象是否相等有多种方法,取决于你对 相等 的定义以及对象属性的类型。以下是几种常见的方法:

 

1. 严格相等运算符 (===)

使用 === 运算符可以比较两个对象是否引用同一个对象。如果两个变量引用了同一个对象,则它们是相等的,否则它们是不相等的。例如:

const obj1 = { a: 1 };
const obj2 = { a: 1 };
const obj3 = obj1;

console.log(obj1 === obj2); // false
console.log(obj1 === obj3); // true

在上面的例子中, obj1 和 obj2 的属性值相同,但它们是不同的对象,因此它们的 === 比较返回 false 。而 obj1 和 obj3 引用了同一个对象,它们是相等的,因此 obj1 === obj3 返回 true 。

这里就是严格比较,引用地址和属性名属性值都要一一对应。

 

 

 

2. 对象属性的比较

如果你只是需要比较两个对象的属性是否相等(不比较引用地址),你可以使用循环或 Object.keys 方法来获取对象属性的列表,并比较它们的值。例如:

function isObjectEqual(obj1, obj2) {
  const obj1Keys = Object.keys(obj1);
  const obj2Keys = Object.keys(obj2);

  if (obj1Keys.length !== obj2Keys.length) {
    return false;
  }

  for (let key of obj1Keys) {
    if (obj1[key] !== obj2[key]) {
      return false;
    }
  }

  return true;
}

const obj1 = { a: 1, b: "hello" };
const obj2 = { a: 1, b: "world" };
const obj3 = { a: 1, b: "hello" };

console.log(isObjectEqual(obj1, obj2)); // false
console.log(isObjectEqual(obj1, obj3)); // true

在上面的例子中, isObjectEqual 函数比较了 obj1 和 obj2 的属性值并返回 false ,因为它们的 b 属性的值不相等。而 isObjectEqual(obj1, obj3) 返回 true ,因为它们的所有属性值都相等。

 

 

 

3. 使用 Lodash 等工具库判断两个对象是否相等

可以使用 Lodash 的 isEqual 方法(依然不比较引用地址)。 isEqual 方法会递归比较两个对象的属性值是否相等,包括嵌套对象和数组。

const obj1 = { a: 1, b: { c: 2 } };
const obj2 = { a: 1, b: { c: 2 } };
const obj3 = { a: 1, b: { c: 3 } };

console.log(_.isEqual(obj1, obj2)); // true
console.log(_.isEqual(obj1, obj3)); // false

在上面的例子中, _.isEqual(obj1, obj2) 返回 true ,因为它们的所有属性值都相等,包括嵌套的对象。而 _.isEqual(obj1, obj3) 返回 false ,因为它们的 b.c 属性的值不相等。

 

 

 

4. JSON.stringify 方法

如果你的对象中只包含简单类型(如数字、字符串、布尔值和 null)以及其他对象或数组,则可以使用 JSON.stringify 方法将对象转换为字符串,然后比较这些字符串(还是不比较引用地址)。例如:

const obj1 = { a: 1, b: "hello", c: true };
const obj2 = { a: 1, b: "hello", c: true };
const obj3 = { a: 1, b: "world", c: true };

console.log(JSON.stringify(obj1) === JSON.stringify(obj2)); // true
console.log(JSON.stringify(obj1) === JSON.stringify(obj3)); // false

在上面的例子中, JSON.stringify(obj1) 和 JSON.stringify(obj2) 都返回相同的字符串,因此它们的比较返回 true 。而 JSON.stringify(obj1) 和 JSON.stringify(obj3) 返回不同的字符串,因此比较返回 false 。

需要注意的是,这种方法只适用于简单类型和嵌套对象或数组,因为它无法处理对象中包含函数、正则表达式和 Date 等类型的情况。

 

5. 使用 Object.is() 方法

它与 === 运算符类似,但是有一些特殊情况,例如 Object.is(+0, -0) 返回 false ,而 === 运算符返回 true 。

const obj1 = { a: 1 };
const obj2 = { a: 1 };
const obj3 = obj1;

console.log(Object.is(obj1, obj2)); // false
console.log(Object.is(obj1, obj3)); // true

在上面的例子中, Object.is(obj1, obj2) 返回 false ,因为 obj1 和 obj2 是两个不同的对象,而 Object.is(obj1, obj3) 返回 true ,因为 obj1 和 obj3 引用了同一个对象。

 

无论你使用哪种方法,都需要明确你对 相等 的定义以及对象属性的类型,并选择适合你需求的方法。

原文链接:https://www.cnblogs.com/ronaldo9ph/p/17380814.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:在JS中如何判断两个对象是否相等 - Python技术站

(0)
上一篇 2023年5月8日
下一篇 2023年5月9日

相关文章

  • jquery中validate与form插件提交的方式小结

    来详细讲解一下“jquery中validate与form插件提交的方式小结”的完整攻略。 一、什么是jQuery Validation? jQuery Validation 是一个非常流行的 jQuery 表单验证插件,它可以帮助我们验证用户输入的数据是否合法。使用jQuery Validation可以方便地进行表单验证,使用方式简单易懂,可以兼容不同浏览器…

    JavaScript 2023年6月10日
    00
  • DOM 事件的深入浅出(一)

    以下是详细讲解“DOM 事件的深入浅出(一)”的完整攻略。 什么是 DOM 事件 DOM 事件指的是由 HTML 页面中的元素触发的事件。例如,当用户在网页上点击一个按钮时,会触发相应的事件处理程序。 DOM 事件的分类 DOM 事件按照产生的顺序可以分为三种类型: 冒泡型事件(Bubbling events):从目标元素开始向外冒泡,直到传递到文档根节点。…

    JavaScript 2023年6月10日
    00
  • js验证模型自我实现的具体方法

    下面是关于”js验证模型自我实现的具体方法”的完整攻略及示例: 1. 确定验证规则及需求 在实现js验证模型之前,需要明确业务场景下需要验证哪些数据和如何验证,需要明确以下几点: 验证的字段名称 验证规则(如是否为空、长度要求、数据类型、特殊字符等要求) 验证提示语(该字段验证未通过时应该显示什么提示) 比如,在一个注册页面中,需要验证用户名、密码和确认密码…

    JavaScript 2023年6月10日
    00
  • JS实现统计字符串中字符出现个数及最大个数功能示例

    下面我将详细讲解“JS实现统计字符串中字符出现个数及最大个数功能示例”的完整攻略。 1. 需求分析 在实现统计字符串中字符出现个数及最大个数功能之前,我们首先需要明确需求。具体来说,我们需要实现以下功能: 统计字符串中每个字符出现的个数; 找出出现次数最多的字符及其出现次数。 2. 实现思路 基于以上需求,我们可以采用以下步骤来实现: 遍历字符串中的每个字符…

    JavaScript 2023年5月28日
    00
  • javascript 函数及作用域总结介绍

    Javascript 函数及作用域总结介绍 Javascript 函数及作用域是 Javascript 学习中最核心和重要的部分之一,下面我们将深入学习并总结它们的基本知识。 函数(Function) 定义 在 Javascript 中,函数是一种数据类型,可以被执行。函数有两种方式定义,一种是函数声明方式,另一种是函数表达式方式。 函数声明方式 funct…

    JavaScript 2023年5月27日
    00
  • js中精确计算加法和减法示例

    JS中精确计算加法和减法可以使用第三方库BigDecimal.js进行操作。以下是完整攻略: BigDecimal.js 简介 BigDecimal.js官方文档:http://mikemcl.github.io/big.js/ 。该库从ECMAScript 5开始可以跨平台使用。该库通过兼容JavaScript中的Number类型来进行扩展和覆盖,返回精确…

    JavaScript 2023年6月10日
    00
  • JS实现简单的操作杆旋转示例详解

    下面我将详细讲解“JS实现简单的操作杆旋转示例”的完整攻略。 简介 “JS实现简单的操作杆旋转示例”是一篇介绍如何用JavaScript实现操作杆旋转效果的文章。该文章主要介绍了操作杆旋转的原理以及如何使用JavaScript实现旋转效果的具体步骤。 实现原理 操作杆旋转效果的原理很简单:通过改变操作杆的位置和旋转角度,来模拟操作杆的旋转过程。具体实现过程包…

    JavaScript 2023年6月10日
    00
  • 浅谈spring中isolation和propagation的用法

    我们来一步步详细讲解。 简介 在Spring中,@Transactional注解可以用于标注事务处理的方法,其中isolation和propagation两个属性用来设置事务的隔离级别和传播特性。本文将主要围绕这两个属性展开讲解。 隔离级别 事务隔离级别是解决数据库并发访问引发的一系列问题的标准。Spring框架提供了五种不同的隔离级别,分别是: ISOLA…

    JavaScript 2023年6月11日
    00
合作推广
合作推广
分享本页
返回顶部