Js如何判断两个数组是否相等?

本文介绍了JavaScript中通过数组自带方法(every,some,filter,findIndex)以及toString(),join(),JSON.stringify()来判断两个数组是否相等的方法,强调了每种方法的限制和适用场景,其中JSON.stringify被推荐为日常开发中的首选。
摘要由CSDN通过智能技术生成


日常开发,时不时会遇到需要判定2个数组是否相等的情况,需要实现考虑的场景有:

  • 先判断长度,长度不等必然不等
  • 元素位置
  • 其他情况考虑
    • '1'1 (Object的key是字符串, Map的key没有限制)
    • NaN
    • nullundefined

1、通过数组自带方法比较

// 方式1
function isArrEqual1(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }
  return arr1.every((v, i) => v === arr2[i]);
  // return !arr1.some((v, i) => v !== arr2[i]);
  // return arr1.filter((v, i) => v !== arr2[i]).length === 0;
  // return arr1.findIndex((v, i) => v !== arr2[i]) === -1;
}

// 测试
const arr1 = [-2, "-1", 0, 0.1, 1, "2", "a", "", undefined, null],
  arr2 = [-2, "-1", 0, 0.1, 1, "2", "a", "", undefined, null];

isArrEqual1(arr1, arr2); // true

数组自带的方法,比较适合的有:every、some、filter、findIndex

这种方式严格限制了数组元素长度、类型、位置必须一致。

注意包含NaN也无法比较!NaN是JS中唯一一个与自身不相等的存在!判断NaN是否属于同一个值得用Object.is(),如:Object.is(NaN, NaN); // true

2、通过循环判断

// 方式2
function isArrEqual2(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }
  for (let i = 0; i < arr1.length; i++) {
    if (arr1[i] !== arr2[i]) {
      return false;
    }
  }
  return true;
}

这种判定方法限制及说明同上述方法1。

3、toString()

// 方式3
function isArrEqual3(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }
  return arr1.toString() === arr2.toString();
}

// 测试
isArrEqual3(arr1, arr2); // true

const arr3 = ['', 1, null, undefined, {}, { a: 1 }, NaN, [], [2, 3], new Date()],
  arr4 = ['', "1", undefined, null, {}, { a: 2 }, NaN, [], [2, "3"], new Date()];

isArrEqual3(arr3, arr4); // true

toString 方法是Object类型对象的实例方法,作用是返回一个对象的字符串形式。

这种方式限制了数组长度和元素位置,但是会发现有些元素类型没有严格限制,这是由于js本身进行的数据隐式转换!

在控制台查看通过toString转化后的数组,得到的结果如下:
在这里插入图片描述

此外,对数组、空数组、对象、空对象等引用类型,由于toString转换结果都是[object Object],所以在比较的时候都会判定为相等!

还有,需要注意:

null == undefined // true
null === undefined // false

4、join()

// 方式4
function isArrEqual4(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }
  return arr1.join() === arr2.join();
}

join 方法是数组的一个实例方法,如果join这个方法如果不传如分割符,其实作用几乎和toString一样,所以实现效果和限制同toString。
在这里插入图片描述

5、JSON.stringify()

// 方式5 [推荐]
function isArrEqual5(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }
  return JSON.stringify(arr1) === JSON.stringify(arr2);
}

// 测试
isArrEqual5(arr1, arr2); // true
isArrEqual5(arr3, arr4); // false

const arr5 = [undefined, null, "", {}, { a: 1 }, NaN, [], [2, 3], new Date()],
  arr6 = [undefined, null, "", {}, { a: 1 }, NaN, [], [2, 3], new Date()];

isArrEqual5(arr5, arr6); // true

JSON.stringify 用于将一个对象或值转换成JSON字符串,转换后结果会带双引号。
在这里插入图片描述

从测试结果可以看到,这个比较方式也严格的限制了数组长度、元素位置和元素类型,在日常中比较推荐此种方案~

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 可以使用JSON.stringify()方法将两个数组转换成字符串,然后再进行比较。例如: ``` function arraysEqual(arr1, arr2) { return JSON.stringify(arr1) === JSON.stringify(arr2); } ``` 这个函数会返回true如果两个数组相等,否则返回false。 ### 回答2: 在JavaScript中,判断两个数组是否相等可以使用循环遍历比较两个数组的每个元素。以下是一种可能的实现方式: 1. 首先,判断两个数组的长度是否相等,如果长度不相等,则这两个数组相等。可以使用`length`属性来获取数组的长度。 2. 如果两个数组长度相等,则可以进一步比较它们的每个元素。可以使用`for`循环来遍历数组。 3. 在循环中,逐个比较两个数组对应位置的元素是否相等。可以使用索引操作符`[]`来获取数组中的元素。 4. 如果在循环中找到不相等的元素,则可以判断两个数组相等,并立即返回`false`。 5. 如果循环结束后没有找到不相等的元素,则可以判断两个数组相等,并返回`true`。 以下是该方法的代码示例: ```javascript function arraysEqual(arr1, arr2) { if (arr1.length !== arr2.length) { return false; } for (let i = 0; i < arr1.length; i++) { if (arr1[i] !== arr2[i]) { return false; } } return true; } ``` 使用该方法,可以判断两个数组是否相等。例如,对于数组`[1, 2, 3]`和`[1, 2, 3]`,调用`arraysEqual`函数会返回`true`。而对于数组`[1, 2, 3]`和`[1, 2, 4]`,调用`arraysEqual`函数会返回`false`。 ### 回答3: 要判断两个数组是否相等,我们可以比较两个数组的长度是否相同。如果长度不同,那么这两个数组肯定不相等。如果长度相同,我们可以逐个比较数组中每个元素是否相同。 首先,我们可以使用`array1.length`和`array2.length`来比较两个数组的长度。如果长度不同,我们可以直接返回false,表示两个数组相等。 如果长度相同,我们可以遍历其中一个数组,使用`array1[i]`和`array2[i]`来比较每个位置上的元素。如果找到两个相等的元素,我们可以直接返回false,表示两个数组相等。 如果遍历完所有元素没有找到不相等的元素,那么两个数组相等的,我们可以返回true表示两个数组相等。 下面是一个使用JavaScript实现的例子: ```javascript function arraysAreEqual(array1, array2) { if (array1.length !== array2.length) { return false; } for (var i = 0; i < array1.length; i++) { if (array1[i] !== array2[i]) { return false; } } return true; } // 使用例子 var a = [1, 2, 3]; var b = [1, 2, 3]; var c = [1, 2, 4]; console.log(arraysAreEqual(a, b)); // 输出true console.log(arraysAreEqual(a, c)); // 输出false ``` 这个例子中的`arraysAreEqual`函数接受两个数组作为参数,返回一个布尔值表示两个数组是否相等。在使用例子中,我们先定义了三个数组`a`、`b`和`c`,然后分别调用`arraysAreEqual`函数来比较它们是否相等。根据数组元素的不同,输出结果会不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

英子的搬砖日志

您的鼓励是我创作的动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值