一尘不染

如何检查一个变量是否是 JavaScript 中的一个数组?

javascript

我想检查一个变量是 JavaScript 中的数组还是单个值。

我找到了一个可能的解决方案......

if (variable.constructor == Array)...

这是最好的方法吗?


阅读 151

收藏
2022-02-13

共2个答案

一尘不染

有几种方法可以检查变量是否为数组。最好的解决方案是您选择的解决方案。

variable.constructor === Array

这是 Chrome 上最快的方法,很可能是所有其他浏览器。所有数组都是对象,因此检查构造函数属性对于 JavaScript 引擎来说是一个快速的过程。

如果您在确定对象属性是否为数组时遇到问题,您必须首先检查该属性是否存在。

variable.prop && variable.prop.constructor === Array

其他一些方法是:

Array.isArray(variable)

使用 Chrome 75 于 2019 年 5 月 23 日更新,让我带着他的问题重新审视这个问题 。在我看来,最后一个是最丑陋的,也是最慢的速度之一。运行速度约为第一个示例的 1/5。这家伙慢了大约 2-5%,但很难说。扎实好用!结果给我留下了深刻的印象。Array.prototype,其实就是一个数组。你可以在这里阅读更多关于它的信息https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/isArray

variable instanceof Array

此方法运行速度约为第一个示例的1/3 。如果您只关注漂亮的代码而不是性能,那么仍然非常可靠,看起来更干净。请注意,检查数字并不像variable instanceof Number往常一样返回false更新:instanceof现在速度提高了 2/3!

所以又一次更新

Object.prototype.toString.call(variable) === '[object Array]';

这家伙是尝试检查阵列最慢的。但是,这是您正在寻找的任何类型的一站式商店。但是,由于您要查找数组,因此只需使用上述最快的方法。

2022-02-13
一尘不染

您还可以使用:

if (value instanceof Array) {
  alert('value is Array!');
} else {
  alert('Not an array');
}

在我看来,这似乎是一个非常优雅的解决方案,但对每个人来说都是他自己的。

编辑:

从 ES5 开始,现在还有:

Array.isArray(value);

但这会在较旧的浏览器上中断,除非您使用的是 polyfills(基本上...... IE8 或类似的)。

2022-02-13