Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >js -【 数组】怎么判断一个变量是数组类型的?

js -【 数组】怎么判断一个变量是数组类型的?

作者头像
xing.org1^
发布于 2018-12-14 06:26:18
发布于 2018-12-14 06:26:18
7.7K00
代码可运行
举报
文章被收录于专栏:前端说吧前端说吧
运行总次数:0
代码可运行

怎么判断一个数组是数组呢?

其实这个也是一个常考的题目。依稀记得我为数不多的面试经过中都被问道过。

方案一: instanceof

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
variable instanceof Array

解决思路:

 使用类型判断所给的方法 instanceof  进行判断。

此方法返回一个布尔值,能够精确判断一个对象的类型。

方案二:原型prototype + toString +  call

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Object.prototype.toString.call(variable).indexOf('Array') !== -1;

因为用了toString方法, 返回值是一个字符串,还需要第二层判断,看字符串中是否有‘Array’这个关键字:

这个字符串中有Array关键字的返回了数字8(就是Array这个字符在整个"[object Array]"中出现的下标数)。

如果变量对象不是一个纯数组,那么返回的数字就是-1。因为indexOf方法在字符串中找不到指定字符就会返回-1.

所以最后还需要通过比对数值是否等于-1就能判断是否是数组类型:

true就是了。

这里可能难以理解的是call方法,毕竟前边toString他们都各司其职。

 首先我们打印出来对象原型上的toString方法返回什么:

这里涉及到Object.prototype.toString()的原理。由于我还学的不深入,就不做总结了,

具体可以看这篇总结的不错:【传送门

大致意思有:

调用toString时会将this对象的[[class]]属性值拿到,而这个属性值就是该对象的真实类型。

[[class]]:一个内部属性,字符串值,表示对象的类型。只有toString这一个方法可以拿到。

而在es5中,toString获取[[class]]值时需要经过这几个比较特殊的步骤:

总结:

调用toString时会将this对象的[[class]]属性值拿到,而这个属性值就是该对象的真实类型。

又因为call能够显示的修改this指针的对象,所以用call将Object内部的this对象指向我们要检测的变量自身。

从而再通过toString拿到变量的[[class]]值。

方案三:原型prototype + isPrototypeOf()方法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Array.prototype.isPrototypeOf(variable) 

isPrototypeOf() 函数 : 用于指示对象是否存在于一个对象的原型链中。如果存在返回true,反之返回false。该方法属Object对象,由于所有的对象都继承了Object的对象实例,因此几乎所有的实例对象都可以使用该方法。

所以在上边代码公式中,如果variable的原型链中存在Array对象,就会返回true,也就说明variable是数组类型。

isPrototypeOf的字面意思也就是a是不是b的原型。

看上图就知道了,Array就是变量m的原型。所以用这个方法就能判断出来。

对比一个类型为“纯”Object的变量打印出来的信息:

就更加一目了然为什么用这个方法就可以判断出来了吧!

方案四:构造函数 constructor

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
variable.constructor.toString().indexOf("Array")== -1

这个一图胜千言:

对比变量a的打印信息,可以看出来,一个数组类型的实例,其原型__proto__.constructor右边是Array关键字。

所以我们可以用这个关键点拿到也给字符串:

然后用方案二的原理差不多的,我们查找字符串中Array关键字的位置是否等于-1。即能得出变量是否为数组类型得了。

方案五:数组方法 isArray()

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Array.isArray(variable);

思路:

js的一个方法,专门用来测试对象是否是Array类型

 在方案一、二、三的基础上,可以总结整理这个isArray的内部原理

然后把方案1234自己封装成isArray()函数。(待做)

2018-11-19  21:06:57

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-11-19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
JavaScript 用七种方式教你判断一个变量是否为数组类型
我们如何判断一个变量是否为数组类型呢? 今天来给大家介绍七种方式,别走开, 这肯定会被问到的~继续往下看吧
@零一
2021/01/29
1.4K0
面试官:怎么判断数组类型?
图片前端面试过程中,面试官常常会问到怎么判断数组?判断数组的方法常见的有以下几种:1. Object.prototype.toString.call() Object.prototype.toString.call([1,2,3,4]) === “[object Array]” true当然此方法也可以判断对象,字符串等任意变量的数据类型2. 原型链判断数组let a = [1,2,3]a.__proto__ === Array.prototypetrue3. ES6方法 Array.isArrayl
前端老道
2022/09/22
8960
判断是否为数组的 JavaScript 方法总结
我们在日常开发中,常常有判断某值类型的需求,今天我们总结一下常见的几种用来判断是否为数组的 JavaScript 方法。
编程三昧
2021/08/22
1.4K0
判断是否为数组的 JavaScript 方法总结
4种Javascript类型检测的方式
今天这篇文章,主要介绍了JavaScript中检测数据类型的4种方式。如果已经会了的可以当成复习,如果还不了解的话,可以认真看看,并加以运用。
winty
2022/04/08
9790
【JavaScript】JavaScript 变量 ⑧ ( 获取变量数据类型 | 使用 typeof 运算符 获取变量数据类型 | 判断 空类型 | 判断 数组类型 | 获取 对象 具体类型 )
在 JavaScript 中 , 使用 typeof 运算符 可以 获取一个变量的 数据类型 , typeof 表达式 返回的是一个 表示 变量类型 的 字符串 , 如 :
韩曙亮
2024/03/18
9040
【JavaScript】JavaScript 变量 ⑧ ( 获取变量数据类型 | 使用 typeof 运算符 获取变量数据类型 | 判断 空类型 | 判断 数组类型 | 获取 对象 具体类型 )
接近完美地判断JS数据类型,可行吗
JS的变量与其他语言的变量有很大区别,因为其变量松散的本质,决定了变量只是在特定时间内用于保存特定值的一个名字而已,变量的值及其数据类型可在声明周期内改变。
JowayYoung
2020/04/01
2K0
接近完美地判断JS数据类型,可行吗
【JS】501- 一文学会判断变量是否为数组
通常我们可以使用 Object.prototype.toString 方法进行判断,详细可以查看《Object.prototype.toString() - MDN - Mozilla》。
pingan8787
2020/02/19
1K0
JavaScript类型判断:解密变量真实身份的神奇技巧
JavaScript是一门弱类型语言,变量的类型是在运行时动态确定的。因此,在处理复杂的代码逻辑时,对于变量的类型判断变得尤为重要。本文将介绍一些JavaScript中常用的类型判断技巧,帮助开发者更好地理解和处理不同类型的变量。
IT_陈寒
2023/12/14
2480
JavaScript类型判断:解密变量真实身份的神奇技巧
JavaScript数据类型判断
instanceof可以用来判断对象是否是某个类的实例。instanceof的实现原理出门左转查看手撕instanceof
闲花手札
2021/09/08
1.1K0
JS的数据类型及其检测
Javascript 有两种数据类型,分别是基本数据类型和引用数据类型。其中基本数据类型包括 Undefined、Null、Boolean、Number、String、Symbol (ES6 新增,表示独一无二的值),而引用数据类型统称为 Object 对象,主要包括对象、数组和函数。接下来我们分别看下两者的特点。
grain先森
2019/03/29
1.9K0
JS的数据类型及其检测
基础 |判断 JS 中的变量类型竟然可以如此简单
前端爱好者的知识盛宴 嗨 这里是IMWEB 一个想为更多的前端人 享知识  助发展 觅福利 有情怀有情调的公众号 欢迎关注转发 让更多的前端技友一起学习发展~ 正文 在 JS 中,有 5 种基本数据类型和 1 种复杂数据类型,基本数据类型有:Undefined, Null, Boolean, Number和String; 复杂数据类型是Object,Object中还细分了很多具体的类型,比如:Array, Function, Date等等。 今天我们就来探讨一下, 使用什么方法判断一个出一个变量的类型。
用户1097444
2022/06/29
2.1K0
基础 |判断 JS 中的变量类型竟然可以如此简单
原生JS | 数据类型检测,并没你想象的那么简单
HTML5学堂-码匠:看上去,JavaScript中的数据类型检测,并没有什么难度,但是……它包含了不少的知识,如果你只知道一个typeof的话,那很建议你读读这篇文章,加强一下~ 最近一个关系很不错的朋友在跳槽,面试一家大型知名互联网公司的时候,面试官问了一个看上去“超级”基础的问题:如何进行数据类型的检测啊? 面试官:能告诉我如何进行数据类型的检测吗? 码匠好友:typeof啊~ 面试官:还有吗? 码匠好友:instanceof 面试官:还有别的吗?你了解几种? 码匠好友:jQuery的isArray、
HTML5学堂
2018/03/13
1.1K0
面试常考手写代码学习技巧总结
我们在面试的时候,经常会被面试官问到几个手写代码的问题。手写一个数组去重复,深拷贝,数组拍平等等。有些小伙伴面试之前准备了,但是在编写的时候还是会忘掉,本文总结了一个如何应对手写代码的大纲,前面是一些基础内容,但是也希望能帮助到你,都会就当复习一遍,嘿嘿。
coder_koala
2020/01/17
1.2K0
JavaScript一些常用 API整理汇总
来源 | https://blog.limeichao.cn/article/9796ce43.html
前端达人
2021/03/16
7430
JavaScript一些常用 API整理汇总
JS中,如何检查对象是否为数组?
最近开源了一个 Vue 组件,还不够完善,欢迎大家来一起完善它,也希望大家能给个 star 支持一下,谢谢各位了。
前端小智@大迁世界
2021/02/02
9.3K0
JS中,如何检查对象是否为数组?
js数据类型
string、number、Boolean、Array、object、Null、Undefined
超然
2018/08/03
4.1K0
js数据类型
JS数据类型分类和判断 转
JavaScript中有6种数据类型:数字(number)、字符串(string)、布尔值(boolean)、undefined、null、对象(Object)。其中对象类型包括:数组(Array)、函数(Function)、还有两个特殊的对象:正则(RegExp)和日期(Date)。
wuweixiang
2019/04/01
3.6K0
JS数据类型分类和判断
                                                                            转
Javascript数组的常用方法和数据类型检测
数组常用的方法 数组的增加、修改、删除 数组的截取和拼接 数组转换为字符串 数组的排序和排列 新增方法 数组的增加、修改、删除 push:向数组的末尾增加新的内容 参数:一项或者多项 返回值:新增加后数组的长度 原数组:已经发生了改变 ary.push(10); //等效于 ary[ary.length] = 10; //等效于 ary.splice(ary.length, 0, 10); pop:删除数组最后一项的内容 参数:无 返回值:被删除的那一项的内容 原数组:已经发生了改变 ary.pop();
江米小枣
2020/06/15
7430
数据类型判断
typeof 操作符返回一个表示数据类型的字符串,它可以应付常规场景下的数据类型判断。对基本数据类型 undefined, boolean, string, number 和引用数据类型 function 都可以正确判断,但是对 null,数组,对象则统一返回 “object”。也就是说,typeof 不适合用来判断引用数据类型。
Chor
2019/11/07
1.6K0
JavaScript中的类型判断
类型判断在 web 开发中有非常广泛的应用,简单的有判断数字还是字符串,进阶一点的有判断数组还是对象,再进阶一点的有判断日期、正则、错误类型,再再进阶一点还有比如判断 plainObject、空对象、Window 对象等等。
ConardLi
2019/05/23
1.5K0
推荐阅读
相关推荐
JavaScript 用七种方式教你判断一个变量是否为数组类型
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验