面试题-如何判断一个对象是不是数组类型
在前端面试中,我们经常会被问道,如何判断一个对象是不是数组类型,下面就这一点展开详细的描述,并总结一下共有几种方法。
1.我们首先回顾一下typeof操作符的用法
操作符可以用来检测给定变量的数据类型,返回的值有以下几种:undefined,boolean,string,number,object,function
2.使用typeof来判断
我们惊喜的发现:除了方法会返回function值之外,[]和{}都是返回的object值,所以无法通过typeof来区分对象还是数组,这种方法不可用。
3.根据构造函数来判断
instanceof操作符可以来表示实例是否属于某个构造函数创建的。
从上图来看,obj1是构造函数Array的实例没问题,obj4也是构造函数的实例类型,显然obj4应该是对象数据类型,为什么会产生这种情况,obj4.__proto__=obj1,obj4改变了它的原型指向,草图如下:
因为改变了obj4的原型指向导致使用instanceof字符判断出obj4也为数组类型了,所以此方法也不可取。
3.使用原型对象判断
发现结果和使用instanceof字符一样,所以还是无法区[]是数组类型
4.根据对象的class属性来判断
class:每个对象的内部属性,记录创建对象时使用的类型名,一旦创建,无法修改。
问题:数组类型等内置类型,重写了toString方法,直接调用数组对象的方法,不在返回class
解决:使用call替换this为指定对象调用Object原型上的toString方法即可。
5.Array.isArray直接判断
Array.isArray() 用于确定传递的值是否是一个 Array。如果对象是 Array,则为true; 否则为false.
综上所述,判断一个对象是不是数组类型最可靠的方法是这两种: Object. prototype.toString.call(obj)===[ object Array]和Array. isArray(obj)。
参考资料:
《JavaScript高级程序设计》 MDN
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现