iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaScript判断两个数组相等的方法有哪些
  • 436
分享到

JavaScript判断两个数组相等的方法有哪些

2023-07-05 04:07:17 436人浏览 薄情痞子
摘要

这篇文章主要介绍“javascript判断两个数组相等的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript判断两个数组相等的方法有哪些”文章能帮助大家解决问题。循环比较使用

这篇文章主要介绍“javascript判断两个数组相等的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript判断两个数组相等的方法有哪些”文章能帮助大家解决问题。

    循环比较

    使用循环的方法一一比较数组元素的值,可能是我们最先能想到的方式。
    循环比较大概可分为两种方式,一种是使用 forwhile 等循环语句,相对简单,如下代码所示:

    const arr1 = [1, 2, 3], arr2 = [1, 2, 3]// 需要判断两个数组长度arr1.length === arr2.length// 一一比较元素值,有一个不相等就不等for (let i = 0; i < arr1.length; i++) {  if (arr2[i] !== arr2[i]) {    return false  }}

    另外一种就是使用数组的循环类实例方法,如 foreachmap 等处理数组循环的实例方法,和使用 for 语句较类似,同样能达到目的。
    而使用 everysomefilter 等这类实例方法,则代码实现上会更简单一些,如下所示:

    const arr1 = [1, 2, 3], arr2 = [1, 2, 3]// 使用everyarr1.length === arr2.length && arr1.every((v,i) => v === arr2[i])// 使用somearr1.length === arr2.length && !arr1.some((v, i) => v !== arr2[i])// 使用filterarr1.length === arr2.length && arr1.filter((v, i) => v !== arr2[i]).length === 0// 使用find和findIndexarr1.length === arr2.length && arr1.findIndex((v, i) => v !== arr2[i]) === -1

    当我们进行循环相关的比较的时候,都使用的是严格相等 ===,会先判断类型是否相等。

    但如果需要忽略元素类型时,可以使用 ==,这样,会自动对数组元素进行类型转换后再比较,如 true == 1 会成立。

    toString

    toString 方法是Object类型对象的实例方法,而js中Object是几乎所有类型的基类,所以其他类型都能调用该方法。(null和undefined例外,没有实例方法。)
    toString方法的作用是返回一个对象的字符串形式,这里,我们用它来返回数组的字符串形式的数据。

    [1,2,3].toString() // '1,2,3'

    以上代码,就是返回数组 [1,2,3] 的字符串形式,以逗号分给元素组成字符串数据,返回的 '1,2,3'
    如果数组元素是复杂类型,如Object对象,则toString返回的结果将不同:

    [1,2,{}].toString() // '1,2,[object Object]'

    这里toString方法对 {} 直接返回的是 [object Object]

    鉴于此,我们比较数组元素为原始类型的数组时,可以如下这样使用:

    [1,2,3].toString() === [1, 2, 3].toString() // true

    需要注意的是,如果数组元素为数字的字符串形式,结果也是相同的:

    ['1', 2, 3].toString() // '1,2,3'[1,2,3].toString() === ['1', 2, 3].toString() // true

    join

    join 方法是数组的一个实例方法。

    它有一个可选参数,可以作为分隔符,以该分隔符分隔所有数组元素组成字符串数据返回,如果不加参数,默认是以逗号分割。

    通过join方法的用法,我们就能知道,如果不提供分隔符的参数,它对数组所起的作用看上去和 toString 方法几乎一样。

    [1,2,3].join() === [1, 2, 3].join() // true[1,2,3].join() === ['1', '2', '3'].join() //true

    当然,也可以添加分隔符,效果是一样的,如使用空字符:

    [1,2,3].join('') // '123'[1,2,3].join('') === ['1', '2', '3'].join('') //true

    由上可知,既然join不带参数和toString方法几乎一样,那它们互相之间的比较,本质上都是数组转换成逗号分隔的字符串,所以也是相等的:

    [1, '2', true].join() === [1, '2', true].toString() // true[1, '2', true].toString() === [1, '2', true].join() // true

    JSON.stringify

    JSON.stringify 用于将一个对象或值转换成JSON字符串,如果是数组,一般会这样转换:

    JSON.stringify([1, '2', true]) // '[1,"2",true]'

    利用这个特点,我们就能通过它进行数组的常规比较:

    [1, 2, 3] === [1, 2, 3] // falseJSON.stringify([1, 2, 3]) === JSON.stringify([1, 2, 3]) // trueJSON.stringify([1, '2', true]) === JSON.stringify([1, '2', true]) // true

    需要注意的是,JSON.stringify处理字符串是转换结果会带双引号:

    JSON.stringify(['1']) // '["1"]'JSON.stringify(['1']) === '["1"]' // trueJSON.stringify(['1']) === '[\'1\']' // false

    关于JSON.stringify方法更多的知识,可查看博文JSON.parse 和 JSON.stringify 详解

    当数组元素是空元素、null、undefined时

    以上介绍的数组元素的类型都是原始类型(String、Number、Boolean),但数组元素还可以是另外三种特殊情况:空元素nullundefined,接下来将简单介绍下出现这三种情况时的比较方式。

    null 和 undefined

    当使用 JSON.stringify 方法时,空元素、null、undefined这三种类型的元素都会被转换成 null 字符串值,可以很好的判断:

    JSON.stringify([1, '2', true, , null, undefined]) // '[1,"2",true,null,null,null]'JSON.stringify([1, '2', true, , null, undefined]) === JSON.stringify([1, '2', true, , null, undefined]) // true

    toStringjoin 方法较类似,他们会把这三种类型的值都转换成空字符:

    [1, '2', true, , null, undefined].join() // '1,2,true,,,'[1, '2', true, , null, undefined].toString() // '1,2,true,,,'[1, '2', true, , null, undefined].toString() === [1, '2', true, , null, undefined].join() // true

    当我们使用上面介绍的第一种循环数组元素的方法进行比较时,null和undefined只需要注意它们两种类型的值是否相等:

    null == undefined // truenull === undefined // false

    使用严格相等比较的时候,这两种类型不相等。

    空元素

    数组元素是空元素时,使用循环方式处理,则会有一些不一样,主要和数组的空元素的特点有关:

    • 数组通过下标读取空元素时,返回undefined。

    • 当使用 forwhilefor-offindfindIndex 等语法时,空元素会返回 undefined 值;undefined值能被比较,所以这时候进行数组元素比较时,结果是正确的。

    • 当使用数组实例方法循环如 forEachmapeverysomefilter 等方法时,空元素会被跳过;由于值被跳过,在使用这些方式进行数组元素比较时,结果可能是错误的。

    const arr1 = [1, 2, , 3], arr2 = [1, 2, 2, 3]arr1.length === arr2.length && arr1.every((v, i) => v === arr2[i]) // truearr1.length === arr2.length && arr1.filter((v, i) => v !== arr2[i]).length === 0 // truearr1.length === arr2.length && !!arr1.find((v, i) => v !== arr2[i]) // falsearr1.length === arr2.length && arr1.findIndex((v, i) => v !== arr2[i]) === -1 // false

    以上代码,数组arr1有一个空元素,与数组arr2的元素并不相同,但是我们使用 everyfilter 比较得到的值为 true,这显然是不对的;而使用 findfindIndex 比较结果为 false ,是正确的。

    关于“JavaScript判断两个数组相等的方法有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

    --结束END--

    本文标题: JavaScript判断两个数组相等的方法有哪些

    本文链接: https://www.lsjlt.com/news/349511.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • c++中if elseif使用规则
      c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
      99+
      2024-05-14
      c++
    • c++中的继承怎么写
      继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
      99+
      2024-05-14
      c++
    • c++中如何使用类和对象掌握目标
      在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
      99+
      2024-05-14
      c++
    • c++中优先级是什么意思
      c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
      99+
      2024-05-14
      c++
    • c++中a+是什么意思
      c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
      99+
      2024-05-14
      c++
    • c++中a.b什么意思
      c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
      99+
      2024-05-14
      c++
    • C++ 并发编程库的优缺点
      c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
      99+
      2024-05-14
      c++ 并发编程
    • 如何在 Golang 中备份数据库?
      在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
      99+
      2024-05-14
      golang 数据库备份 mysql git 标准库
    • 如何在 Golang 中优雅地处理错误?
      在 go 中,优雅处理错误包括:使用 error 类型;使用 errors 包函数和类型;自定义错误类型;遵循错误处理模式,包括关闭资源、检查错误、打印错误信息和处理或返回错误。 在 ...
      99+
      2024-05-14
      golang 错误处理
    • 如何构建 Golang RESTful API,并使用中间件进行身份验证?
      本文介绍了如何构建 golang restful api。首先,通过导入必要的库、定义数据模型和创建路由来构建 restful api。其次,使用 go-chi/chigot 和 go-...
      99+
      2024-05-14
      golang git
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作