JavaScript判断对象是否为数组

作者:lijiao 时间:2024-04-22 22:42:14 

文中为大家分享了三种JavaScript判断对象是否为数组的方法,

1. typeof

首先我们会想到的是使用typeof来检测数据类型,但是对于Function, String, Number, Undefined等这几种基本类型来说,使用typeof来检测都可以检测到,比如代码如下:


function test(){}
console.log(typeof 1); // number
console.log(typeof test); // function
console.log(typeof "yunxi"); // string
console.log(typeof undefined); // undefined

但是对于数组或者正则来说,使用typeof来检测的话,那就满足不了,因为当我们检测数组或者正则的话,那么返回的类型将会是一个对象object,如下代码所示:


console.log(typeof []); // object
console.log(typeof /\d+/g); // object

2. Instanceof

由此我们很容易会想到使用instanceof来检测某个对象是否是数组的实例,该检测会返回一个布尔型(boolean),如果是数组的话,返回true,否则的话返回false;我们再来看下上面的检测是否为数组的代码如下:


console.log([] instanceof Array); // true
console.log(/\d+/g instanceof Array); // false

如上可以看到使用instanceof确实可以判断是否为数组的列子;
3. constructor属性

在javascript中,每个对象都有一个constructor属性,它引用了初始化该对象的构造函数,比如判断未知对象的类型,因此我们可以如下写一个方法,代码如下:


function isArray(obj) {
 return typeof obj == 'object' && obj.constructor == Array
}
// 测试demo
console.log(isArray([])); // true
var a = {"a":1};
console.log(isArray(a)); // false

var b = [1,2,3];
console.log(isArray(b)); // true
console.log(isArray(/\d+/g));// false

如上可以看到,通过调用isArray 方法也可以判断是否为数组的列子。
我们现在可以看到,对于第二点和第三点分别使用instanceof方法和constructor属性貌似都可以来判断是否为数组了,但是也有列外情况,比如在跨框架iframe的时候使用页面中的数组时,会失败,因为在不同的框架iframe中,创建的数组是不会相互共享其prototype属性的;如下代码测试即可得到验证~


var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;    
var arr = new xArray("1","2","3","4","5");
//这个写法IE下是不支持的,标准浏览器firefox,chrome下有

console.log(arr); // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false
console.log(arr.constructor === Array); // false

如上的方法我们都不能来判断一个对象是否为数组的方式; 但是我们在看ECMA262中可以看到,可以使用 Object.prototype.toString.call()方法来判断一个对象是否为数组;如下代码:


function isArray(obj) {
 return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代码调用
console.log(isArray([])); // true
console.log(isArray([1,2,3])); // true

var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;    
var arr = new xArray("1","2","3","4","5");

console.log(arr); // ["1","2","3","4","5"]
console.log(isArray(arr)); // true
标签:JavaScript,对象,数组
0
投稿

猜你喜欢

  • python中format函数如何使用

    2022-06-18 06:50:41
  • 详解pytorch 0.4.0迁移指南

    2023-04-10 08:02:14
  • 详解MySQL主键唯一键重复插入解决方法

    2024-01-20 16:41:22
  • jsp页面中获取servlet请求中的参数的办法详解

    2023-06-19 10:52:00
  • python实现密码验证合格程序的思路详解

    2022-12-10 05:07:38
  • Python实现点云投影到平面显示

    2021-05-10 14:51:15
  • 4个场景教会你Go中Goroutine和通道是怎么用的

    2024-04-23 09:45:05
  • asp中如何对ip段进行过滤限制

    2007-09-17 11:14:00
  • vue中resetFields重置初始值不生效的原因详解

    2024-05-29 22:29:12
  • 基于python+opencv调用电脑摄像头实现实时人脸眼睛以及微笑识别

    2023-07-08 23:31:14
  • PHP登录(ajax提交数据和后台校验)实例分享

    2024-04-28 09:43:41
  • Python之random库的常用函数有哪些

    2022-10-04 03:01:13
  • Windows10下Tensorflow2.0 安装及环境配置教程(图文)

    2022-03-31 04:02:28
  • vue地区选择组件教程详解

    2023-07-02 16:49:48
  • Go逃逸分析示例详解

    2024-04-25 15:05:22
  • Python实现学生管理系统(面向对象版)

    2021-11-05 01:20:54
  • 5分钟快速掌握Python定时任务框架的实现

    2023-05-31 10:19:45
  • php 保留小数点

    2023-06-21 10:47:04
  • asp中的on error resume next用法

    2008-03-09 15:22:00
  • python实现的用于搜索文件并进行内容替换的类实例

    2022-01-07 13:50:43
  • asp之家 网络编程 m.aspxhome.com