Bootstrap

如何判断数组的四种方法

日常中我们会用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)。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;