【JS】判断是否为数组的几种方式及各自的缺陷

1. Object.prototype.toString.call

const arr = [1,2,3]
const obj = {}
Object.prototype.toString.call(arr) === '[object Array]' // true
Object.prototype.toString.call(obj) === '[object Array]' // false

ES6引入知名符号 toStringTag 之前,这种方法是适用的,因为无法修改字符串'[object Array]'。但如果使用知名符号 toStringTag 手动修改后,则无法正确校验。

const obj = {
    name: "田本初",
    age: 23,
    [Symbol.toStringTag]: 'Array'
}
Object.prototype.toString.call(obj) === '[object Array]'  // true

2. instanceof

检查是否是Array构造函数的实例

const arr = [1,2]
const obj = {}
class A extends Array {}
const a = new A()

arr instanceof Array // true
a instanceof Array // true
obj instanceof Array // false

这种方式不会受到ES6引入的知名符号 toStringTag 的影响

const obj = {
    name: "田本初",
    age: 23,
    [Symbol.toStringTag]: 'Array'
}
obj instanceof Array // false

但是也有缺陷,如手动修改原型

const obj = {}
Object.setPrototypeOf(obj,Array.prototype)
obj instanceof Array // true

如果页面中有iframe,则会失效
因为 ArrayWindow 的全局属性,iframe 中也有其自己的 Window 对象。

const Array1 = Window.Array;
const iframe = document.querySelector('iframe');
const Array2 = iframe.contentWindow.Array;

console.log(Array1 === Array2); // false

如果数组为iframe中Window对象创建的,则无法根据当前页Window的Array判断

const Array1 = Window.Array;
const iframe = document.querySelector('iframe');
const Array2 = iframe.contentWindow.Array;
const arr = new Array2(1, 2, 3);

console.log(arr instanceof Array); // false

3. Array.isArray

简单可靠,推荐使用

知名符号 toStringTag 情况:

const obj = {
    name: "田本初",
    age: 23,
    [Symbol.toStringTag]: 'Array'
}

Array.isArray(obj) // false

iframe不同Window对象的情况:

const Array1 = Window.Array;
const iframe = document.querySelector('iframe');
const Array2 = iframe.contentWindow.Array;
const arr = new Array2(1, 2, 3);

Array.isArray(arr) // true

总结

最推荐使用 Array.isArray,简单可靠。
Object.prototype.toString.call 无法处理使用知名符号toStringTag修改后的对象;
instanceof 无法判断手动修改原型指向和不同的全局作用域创建的数组的情况。

JavaScript中,可以使用多种方法来判断一个变量是否为数组类型: 1. 使用`Array.isArray()`方法: `Array.isArray()`是ES5引入的一个方法,用于检测传入的参数是否为数组类型。它是判断数组的最直接和安全的方式。 示例代码: ```javascript var arr = [1, 2, 3]; var isArr = Array.isArray(arr); console.log(isArr); // 输出:true ``` 2. 使用`typeof`操作符: `typeof`操作符对于数组的判断并不是特别准确,因为`typeof`对于数组会返回"object"。但是,如果需要区分数组和其他对象类型,`typeof`可以作为一种辅助方法。 示例代码: ```javascript var arr = [1, 2, 3]; var isArr = typeof arr === 'object' && arr !== null && typeof arr.length === 'number'; console.log(isArr); // 输出:true ``` 3. 使用`instanceof`操作符: `instanceof`操作符可以用来判断一个对象是否是某个构造函数的实例。对于数组,可以使用`arr instanceof Array`来判断。 示例代码: ```javascript var arr = [1, 2, 3]; var isArr = arr instanceof Array; console.log(isArr); // 输出:true ``` 4. 使用`constructor`属性: 可以通过检查变量的`constructor`属性是否指向`Array`构造函数来判断是否数组。 示例代码: ```javascript var arr = [1, 2, 3]; var isArr = arr.constructor === Array; console.log(isArr); // 输出:true ``` 需要注意的是,`constructor`属性和`instanceof`操作符都有可能因为JavaScript的原型链继承机制而产生误判,尤其是在不同iframe或者经过某些特殊处理(如重写原型链)的情况下。因此,`Array.isArray()`方法是最推荐的判断数组方式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

田本初

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值