温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JavaScript如何判断数组

发布时间:2022-02-16 11:41:11 来源:亿速云 阅读:122 作者:iii 栏目:开发技术

这篇文章主要介绍“JavaScript如何判断数组”,在日常操作中,相信很多人在JavaScript如何判断数组问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript如何判断数组”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    根据构造函数判断

    instanceof

    判断一个实例是否属于某构造函数

    let arr = []
    console.log(arr instanceof Array) // true

    缺点: instanceof 底层原理是检测构造函数的 prototype 属性是否出现在某个实例的原型链上,如果实例的原型链发生变化,则无法做出正确判断。

    let arr = []
    arr.__proto__ = function() {}
    console.log(arr instanceof Array) // false

    constructor

    实例的构造函数属性 constructor 指向构造函数本身。

    let arr = []
    console.log(arr.constructor === Array) // true

    缺点: 如果 arr 的 constructor 被修改,则无法做出正确判断。

    let arr = []
    arr.constructor = function() {}
    console.log(arr.constructor === Array) // false

    根据原型对象判断

    __ proto __

    实例的 __ proto __ 指向构造函数的原型对象

    let arr = []
    console.log(arr.__proto__ === Array.prototype) // true

    缺点:  如果实例的原型链的被修改,则无法做出正确判断。

    let arr = []
    arr.__proto__ = function() {}
    console.log(arr.__proto__ === Array.prototype) // false

    Object.getPrototypeOf()

    Object 自带的方法,获取某个对象所属的原型对象

    let arr = []
    console.log(Object.getPrototypeOf(arr) === Array.prototype) // true

    缺点:  同上

    Array.prototype.isPrototypeOf()

    Array 原型对象的方法,判断其是不是某个对象的原型对象

    let arr = []
    console.log(Array.prototype.isPrototypeOf(arr)) // true

    缺点:  同上

    根据 Object 的原型对象判断

    Object.prototype.toString.call()

    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()

    Array.isArray() 是 ES6 新增的方法,专门用于数组类型判断,原理同上。

    let arr = []
    console.log(Array.isArray(arr)) // true

    修改原型链不会对它造成任何影响。

    let arr = []
    arr.__proto__ = function() {}
    console.log(Array.isArray(arr)) // true

    到此,关于“JavaScript如何判断数组”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI