如何判断数组的四种方法

日常中我们会用typeOf运算符去判断数据的类型,结果如下
在这里插入图片描述
其中对于对象和数组用typeof方法得到的结果都是object,这是因为在JavaScript中所有数据类型严格意义上都是对象,对象是对象,数组也是对象,显然用typeof是不能够判断出变量的类型是数组。

那么接下来介绍判断变量为数组的四种方法👇

1、从原型入手:Array.prototype.isPrototypeOf(obj);

利用isPrototypeOf()方法,判定Array是不是在obj的原型链中,如果是,则返回true,否则false。
在这里插入图片描述

2、从构造函数入手:obj instanceof Array

先说说 typeof 和 instanceof 的区别?
两者都可以用来判断变量,typeof会返回基本类型,如文章开头所示,而instanceof只会返回一个布尔值,如下:

在这里插入图片描述

上面的方法也可以利用对象的constructor属性,例如:typeof arr == "object" && arr.constructor == Array;先判断变量是对象再进一步判断数组。
注意:跨框架页面中的数组,在不同的框架中创建的数组不会相互共享其prototype属性。

3、跨原型链调用toString():Object.prototype.toString.call(obj)

每一个继承 Object 的对象都有 toString方法,如果 toString 方法没有重写的话,会返回 [Object type],其中 type 为对象的类型。但当变量类型不为对象时,使用 toString 方法会直接返回数据内容的字符串,所以我们需要使用call或者apply方法来改变toString方法的执行上下文。

变量类型分为:基本类型和引用类型

  • 基本类型:Number(数字类型),String(字符串类型),Boolean(布尔类型),Undefined,Null
  • 引用类型:大多数是Obiect(对象)

非对象变量使用toString例子:

const an = ['Hello','An'];
an.toString(); // "Hello,An"
Object.prototype.toString.call(an); // "[object Array]"

这种方法对于所有基本的数据类型都能进行判断,即使是 null 和 undefined 。

4、ES5新增的方法:Array.isArray()

在这里插入图片描述

在MDN中就比较了isArray和instanceof的区别,当Array.isArray()不可用的使用时还是比较推荐使用前面讲的第三种方法 Object.prototype.toString.call(obj)。

在JavaScript中,有多种方法可以判断数组中是否存在某个元素。其中一种方法是使用数组的indexOf()方法。这个方法会返回元素在数组中的索引,如果元素不存在则返回-1。例如,可以使用以下代码来判断数组arr中是否存在元素66: ```javascript var arr = \[100, 20, 50, 58, 6, 69, 36, 45, 78, 66, 45\]; if (arr.indexOf(66) === -1) { console.log("不存在"); } else { console.log("存在,索引是:" + arr.indexOf(66)); } ``` 这段代码首先使用indexOf()方法查找元素66在数组arr中的索引,如果返回值为-1,则表示元素不存在,否则表示元素存在,并打印出索引值。\[1\] 除了indexOf()方法,还可以使用其他方法判断数组中是否存在某个元素,比如使用jQuery的$.inArray()方法数组实例的find()方法、findIndex()方法,或者使用for循环和if判断。这些方法的具体用法可以参考引用\[2\]和引用\[3\]中的代码示例。 总结起来,判断数组中是否存在某个元素可以使用indexOf()方法、$.inArray()方法、find()方法、findIndex()方法或者使用for循环和if判断。具体使用哪种方法可以根据实际情况选择。 #### 引用[.reference_title] - *1* *3* [js判断数组中是否存在某个元素(四种方法)](https://blog.csdn.net/anzhenxi3529/article/details/125523556)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [js判断数组中是否存在某一数值的五种方法](https://blog.csdn.net/qq_19176681/article/details/103711230)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值