当前栏目
JS 判断数组的方法总结,哪种最靠谱?
我们从妈妈、爸爸、祖先三个角度来进行判断。
根据构造函数判断(妈妈)
instanceof
判断一个实例是否属于某构造函数
缺点: instanceof 底层原理是检测构造函数的 prototype 属性是否出现在某个实例的原型链上,如果实例的原型链发生变化,则无法做出正确判断。
constructor
实例的构造函数属性 constructor 指向构造函数本身。
缺点: 如果 arr 的 constructor 被修改,则无法做出正确判断。
根据原型对象判断(爸爸)
__ proto __
实例的 __ proto __ 指向构造函数的原型对象
缺点: 如果实例的原型链的被修改,则无法做出正确判断。
Object.getPrototypeOf()
Object 自带的方法,获取某个对象所属的原型对象
缺点: 同上
Array.prototype.isPrototypeOf()
Array 原型对象的方法,判断其是不是某个对象的原型对象
缺点: 同上
原型对象判断(祖先)
根据 Object 的原型对象判断
Object.prototype.toString.call()
Object 的原型对象上有一个 toString 方法,toString 方法默认被所有对象继承,返回 "[object type]" 字符串。但此方法经常被原型链上的同名方法覆盖,需要通过 Object.prototype.toString.call() 强行调用。
这个类型就像胎记,一出生就刻在了身上,因此修改原型链不会对它造成任何影响。
Array.isArray()
Array.isArray() 是 ES6 新增的方法,专门用于数组类型判断,原理同上。
修改原型链不会对它造成任何影响。
总结
以上就是判断是否为数组的常用方法,相信不用说大家也看出来 Array.isArray 最好用、最靠谱了吧,还是ES6香!
相关文章
- 使用 System.Text.Json 时,如何处理 Dictionary 中 Key 为自定义类型的问题
- 如何使用 System.Text.Json 序列化 DateTimeOffset 为 Unix 时间戳
- javascript使用正则表达式替换或者捕获子字符串
- FastAPI从入门到实战(14)——JSON编码兼容与更新请求
- node与浏览器中的cookie
- 使用JSONPath解析json数据
- JS函数hook
- JS代码之混淆
- JS代码之还原
- JavaScript中的二进制数据
- rollup.js 初体验
- vivo悟空活动中台-打造 Nodejs 版本的MyBatis
- 前端科普系列(3):CommonJS 不是前端却革命了前端
- 前端科普系列(2):Node.js 换个角度看世界
- 探究JS V8引擎下的“数组”底层实现
- JavaScript 引擎 V8 执行流程概述
- 如何编写高质量的 JS 函数(4) --函数式编程[实战篇]
- 为什么 JavaScript 中 0.1+0.2 不等于 0.3 ?
- Javascript之旅——终点站:困惑的settimeout
- Javascript之旅——第十一站:原型也不好理解?