JS有多少方法可以判断数组,什么方法好?
Admin 2022-11-01 群英技术资讯 946 次浏览
在实际应用中,我们有时候会遇到“JS有多少方法可以判断数组,什么方法好?”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“JS有多少方法可以判断数组,什么方法好?”文章能帮助大家解决问题。无论在工作还是面试中,我们都会遇到判断一个数据是否为数组的需求,今天我们就来总结一下,到底有多少方法可以判断数组,看看哪种方法是最好用、最靠谱的。
我们从妈妈、爸爸、祖先三个角度来进行判断。
判断一个实例是否属于某构造函数
let arr = [] console.log(arr instanceof Array) // true
缺点: instanceof 底层原理是检测构造函数的 prototype 属性是否出现在某个实例的原型链上,如果实例的原型链发生变化,则无法做出正确判断。
let arr = []
arr.__proto__ = function() {}
console.log(arr instanceof Array) // false
实例的构造函数属性 constructor 指向构造函数本身。
let arr = [] console.log(arr.constructor === Array) // true
缺点: 如果 arr 的 constructor 被修改,则无法做出正确判断。
let arr = []
arr.constructor = function() {}
console.log(arr.constructor === Array) // false
实例的 __ proto __ 指向构造函数的原型对象
let arr = [] console.log(arr.__proto__ === Array.prototype) // true
缺点: 如果实例的原型链的被修改,则无法做出正确判断。
let arr = []
arr.__proto__ = function() {}
console.log(arr.__proto__ === Array.prototype) // false
Object 自带的方法,获取某个对象所属的原型对象
let arr = [] console.log(Object.getPrototypeOf(arr) === Array.prototype) // true
缺点: 同上
Array 原型对象的方法,判断其是不是某个对象的原型对象
let arr = [] console.log(Array.prototype.isPrototypeOf(arr)) // true
缺点: 同上
Object 的原型对象上有一个 toString 方法,toString 方法默认被所有对象继承,返回 "[object type]" 字符串。但此方法经常被原型链上的同名方法覆盖,需要通过 Object.prototype.toString.call() 强行调用。
let arr = [] console.log(Object.prototype.toString.call(arr) === '[object Array]') // true
这个类型就像胎记,一出生就刻在了身上,因此修改原型链不会对它造成任何影响。
let arr = []
arr.__proto__ = function() {}
console.log(Object.prototype.toString.call(arr) === '[object Array]') // true
Array.isArray() 是 ES6 新增的方法,专门用于数组类型判断,原理同上。
let arr = [] console.log(Array.isArray(arr)) // true
修改原型链不会对它造成任何影响。
let arr = []
arr.__proto__ = function() {}
console.log(Array.isArray(arr)) // true
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家介绍了关于VUE+Canvas实现简单五子棋游戏的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
目录背景实现水印恶意修改MutationObserver背景大家平时在开发中或者在面试中,难免都会遇到一个问题——给页面加水印,其实这并不难,但是也是有一些注意点的,所以说看似简单的功能,要尽力做到:1、严谨性2、安全性实现水印其实实现水印并不难,只需要利用自定义指令 + canvas + background-ima
本篇文章就来给大家介绍一些你不知道的Node express 路由使用技巧,希望对大家有所帮助!
这篇文章给大家分享的是React中实现页面跳转的方法,文中给大家介绍了三种方法。小编觉得挺实用的,因此分享给大家做个参考,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
本文主要讲解了如何在vue中使用pdfjs预览pdf文件,这样的优势是无须让用户安装专门的软件即可实现预览,下面就看看如何实现这个需求
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008