位置: IT常识 - 正文

JavaScript数组(四):判断数组相等的4种方法

编辑:rootadmin
JavaScript数组(四):判断数组相等的4种方法 文章目录前言循环比较toStringjoinJSON.stringify当数组元素是空元素、null、undefined时null 和 undefined空元素总结前言

推荐整理分享JavaScript数组(四):判断数组相等的4种方法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

在JavaScript中,数组本质上是一种特殊的对象,它的类型值会返回 object。 如果我们需要比较两个数组是否相等,不能像比较基本类型(String、Number、Boolean等)一样,使用 === (或 ==) 来判断,所以如果要比较数组是否相等,需要使用一些特殊方法。关于JS类型的判断,可见博文 typeof使用详解。

本文总结了几种数组比较的方法,方便我们碰到类似问题时能快速处理:

循环比较toString方法join方法JSON.stringify

需要说明的,这里只针对数组元素为原始类型(String、Number、Boolean)的情况。 如果数据元素是复杂类型,如Object、Function等等,则无法通过这些方法进行简单比较了,需要另行特殊处理。而且当存在这类复杂类型时,比较数组是否相等已经意义不大,本文不做讨论。

这也是关于数组的第四篇博文,前面三篇如下:

JavaScript数组(一):类型、判断、索引与length属性 JavaScript数组(二):创建方式、构造函数、空元素与in运算符 JavaScript数组(三):类数组对象

循环比较

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

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 }}

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

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() // truejoinJavaScript数组(四):判断数组相等的4种方法

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() // trueJSON.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使用详解。

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

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

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

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

[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。当使用 for、while、for-of、find、findIndex 等语法时,空元素会返回 undefined 值;undefined值能被比较,所以这时候进行数组元素比较时,结果是正确的。当使用数组实例方法循环如 forEach、map、every、some、filter 等方法时,空元素会被跳过;由于值被跳过,在使用这些方式进行数组元素比较时,结果可能是错误的。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的元素并不相同,但是我们使用 every 和 filter 比较得到的值为 true,这显然是不对的;而使用 find 和 findIndex 比较结果为 false ,是正确的。

总结

以上四类数组比较的方式,依据我测试的结果,速度上,循环方式中的 for 语法是最快的,而且该方式还能正确比较空元素、null、undefined三种特殊情况,综合上看使用for循环是最佳选择。

第一种循环类方式,性能表现整体优于另外三种方式。 join方法比toString方法更耗时。 如果数据量不是很大,这几种方式耗时可能都在0.1ms以内,几乎可以忽略。

最后,我们总结下以上内容,主要介绍了四种能够比较常规数组(数组为原始数据类型)是否相等的四种方式。也介绍了当数组元素是另外三种特殊情况(空元素、null、undefined)时,上面介绍的四种比较方式是否有效。当然,如果数组元素是复杂数据类型如Object、Function等则比较无意义,不在本文讨论范围内。

本文链接地址:https://www.jiuchutong.com/zhishi/299464.html 转载请保留说明!

上一篇:【YOLOv7】Python基于YOLOv7的人员跌倒检测系统(源码&部署教程&数据集)(python yolo)

下一篇:在Vue3项目中使用VueCropper裁剪组件(裁剪及预览效果)(vue项目使用rem)

  • ipadair4可以用一代笔吗(ipad air4可以用一代applepencil吗)

    ipadair4可以用一代笔吗(ipad air4可以用一代applepencil吗)

  • 苹果11微信闪光灯如何设置(苹果11微信闪光灯怎么闪一下就不闪了)

    苹果11微信闪光灯如何设置(苹果11微信闪光灯怎么闪一下就不闪了)

  • 华为mate30pro有没有必要贴膜呢(华为mate30pro有没有反向充电)

    华为mate30pro有没有必要贴膜呢(华为mate30pro有没有反向充电)

  • 抖音怎么隐藏视频(抖音怎么隐藏视频简介)

    抖音怎么隐藏视频(抖音怎么隐藏视频简介)

  • 电子器件有哪些(柔性电子器件有哪些)

    电子器件有哪些(柔性电子器件有哪些)

  • 微信辅助功能没有视频怎么办(微信辅助功能没有通讯录助手)

    微信辅助功能没有视频怎么办(微信辅助功能没有通讯录助手)

  • 手机打印工场无法选择打印机(手机打印服务)

    手机打印工场无法选择打印机(手机打印服务)

  • qq拉黑对方,对方的列表还有没有自己(qq拉黑对方对方发消息过来会显示什么)

    qq拉黑对方,对方的列表还有没有自己(qq拉黑对方对方发消息过来会显示什么)

  • 华为手机怎么监听另一个华为手机(华为手机怎么监控华为平板)

    华为手机怎么监听另一个华为手机(华为手机怎么监控华为平板)

  • iphone11机身多少厘米(苹果11机身多重多少克)

    iphone11机身多少厘米(苹果11机身多重多少克)

  • 华为手机微信怎么设置指纹解锁(华为手机微信怎么开美颜视频聊天)

    华为手机微信怎么设置指纹解锁(华为手机微信怎么开美颜视频聊天)

  • 笔记本耗电快正常吗(笔记本耗电太快正常吗)

    笔记本耗电快正常吗(笔记本耗电太快正常吗)

  • 光纤入户和网线入户的区别(光纤入户和网线咱连接)

    光纤入户和网线入户的区别(光纤入户和网线咱连接)

  • 换货卖家不发货怎么办(换货卖家不发货,退款怎么处理)

    换货卖家不发货怎么办(换货卖家不发货,退款怎么处理)

  • 如何将视频和图片拼在一起(如何将视频和图片压缩在一起)

    如何将视频和图片拼在一起(如何将视频和图片压缩在一起)

  • 手机手电筒怎么打开(手机手电筒怎么打不开)

    手机手电筒怎么打开(手机手电筒怎么打不开)

  • 手机识别码有什么用(手机识别码有什么作用及危害)

    手机识别码有什么用(手机识别码有什么作用及危害)

  • 滴滴静默多久自动解封(滴滴出行静默了怎么办)

    滴滴静默多久自动解封(滴滴出行静默了怎么办)

  • 什么叫数字化技术(什么叫数字化技术的应用)

    什么叫数字化技术(什么叫数字化技术的应用)

  • 如何在微拍堂卖东西(微拍堂怎么卖)

    如何在微拍堂卖东西(微拍堂怎么卖)

  • oppor11有悬浮球功能吗(oppor11s悬浮球)

    oppor11有悬浮球功能吗(oppor11s悬浮球)

  • qq闺蜜关系怎么建立(qq怎么变成情侣关系)

    qq闺蜜关系怎么建立(qq怎么变成情侣关系)

  • 全网通4g和移动4g有什么区别(全网4g和移动4g)

    全网通4g和移动4g有什么区别(全网4g和移动4g)

  • 微信号被限制多久解封(微信号被限制多个功能期间还会被人再次投诉)

    微信号被限制多久解封(微信号被限制多个功能期间还会被人再次投诉)

  • 1加7是什么手机(一加7m是什么)

    1加7是什么手机(一加7m是什么)

  • 华为mate20自动锁屏(mate自动锁屏)

    华为mate20自动锁屏(mate自动锁屏)

  • msqry32.exe进程是什么文件 作用是什么 msqry32进程查询

    msqry32.exe进程是什么文件 作用是什么 msqry32进程查询

  • vue.config.js配置proxy代理解决跨越;proxy代理报404;(vueconfigjs配置proxy 无效)

    vue.config.js配置proxy代理解决跨越;proxy代理报404;(vueconfigjs配置proxy 无效)

  • Vue开发实例(20)之实现登录功能(vue企业开发实战)

    Vue开发实例(20)之实现登录功能(vue企业开发实战)

  • 收取境外服务费收入如何开票
  • 劳务发票要交多少税费
  • 车船使用税2021
  • 总公司设立分公司的决定
  • 制造费用结转成什么
  • 货运代理公司会计涉及的科目
  • 法人贷款用于公司经营的分录怎么做
  • 退货重新下单要付款吗
  • 单位购置汽车如何入账
  • 小企业准则适用范围
  • 冲暂估成本的会计分录
  • 贸易公司买进卖出
  • 广告公司税收分析
  • 个体户超过3万怎么纳税
  • 增值税需要计提吗
  • 兼职取酬案例剖析
  • 商业承兑汇票贴现转让
  • 分期付款确认收入借方写啥
  • 计提坏账准备需要纳税调增吗
  • 将自产产品无偿赠送 会计处理
  • 暂估成本一直拿不到发票
  • 公司支付给个人的货款怎么入账
  • 加工费的增值税计入什么科目
  • 0x000000a5蓝屏代码是什么意思
  • 忘记excel工作表保护密码怎么办
  • 退休返聘工资如何申报个人所得税
  • 监事会成员是什么人
  • 公司付款给个人,怎么处理
  • 公司收到搬运发票怎么做
  • 电力安装工程辅料有哪些
  • pkjobs.exe - pkjobs是什么进程 有什么用
  • laravel视频教程
  • 移民美国怎样加入医疗保险
  • 财务费用的核算属于什么业务
  • spring三级缓存有什么用
  • php无限分类实现不实用递归
  • php 微信公众号自定义菜单
  • 金碟怎么初始化
  • 边际贡献总额计算公式边际贡献率
  • 增值税附表3
  • 社保可以抵扣吗
  • 用友t3怎么结转本年利润
  • Mysql获取当前年份
  • 企业跨区变更地址需要多久
  • 建筑业异地预交税款怎么入库
  • 外经证报验登记流程
  • 预付账款如何调平
  • 固定资产出售的收入属于收入吗
  • 将现金存入银行编制什么凭证
  • 进项税额增值税专用发票
  • 一般纳税人增值税减免政策2023
  • 银行承兑汇票向银行申请贴现会计分录
  • 车费属于什么会计科目类
  • 住院伙食补助费每天50
  • 不能抵扣的会计分录
  • sqlserver存储过程怎么查看
  • 出现错误,请联系客服
  • 从几个方面论述
  • 虚拟机linux使用
  • win8怎么关闭系统更新
  • win7音量图标不能启用
  • xp 更新
  • win8.1网络设置
  • windows10使用说明
  • linux计划任务每天执行一次
  • unity g
  • jquery 获取json的key
  • node定时任务框架
  • linux搭载服务器
  • 批处理怎么学
  • 请问木瓜
  • jquery easy ui
  • Jquery+ajax+JAVA(servlet)实现下拉菜单异步取值
  • python字符串字符对应个数
  • 廊坊银行辟谣了吗
  • 江西省税务局12366
  • 诺诺发票怎样上报汇总
  • 一月份纳税申报
  • 电子税务局开发票流程
  • 船舶吨税多少天缴纳一次
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设