为了账号安全,请及时绑定邮箱和手机立即绑定

判断JS变量是不是数组

标签:
JavaScript

各声明一个数组和对象变量

目的为了下面测试

let arr = [1, 2, 3, 4, 5];
let obj = {
    name: 'bobobo'
}

方法一: 使用instanceof方法

instanceof判断原理:通过arr的原型链(__proto__)一层层往上进行查询,能否找到对应的构造函数的原型对象(prototype),如果找到了就返回true,反之false。

console.log(arr instanceof Array); // true
console.log(obj instanceof Array); // false

方法二:使用Array.prototype.isPrototypeOf()方法

利用isPrototypeOf()方法,判定Array是不是在obj的原型链中,如果是,则返回true,否则false。

console.log(Array.prototype.isPrototypeOf(arr)); // true
console.log(Array.prototype.isPrototypeOf(obj)); // false

方法三:使用constructor方法

constructor构造函数指向的是创建它的构造函数。

console.log(arr.constructor === Array); // true
console.log(obj.constructor === Array);  // false

方法四:使用Array.isArray()方法

ES6最新方法

console.log(Array.isArray(arr)); // true
console.log(Array.isArray(obj)); // false

方法五:使用Object.prototype.toString.call()方法(推荐)

使用Object.prototype上的原生toString()方法判断数据类型

console.log(Object.prototype.toString.call(arr) === '[object Array]'); // true
console.log(Object.prototype.toString.call(obj) === '[object Object]'); // true

这里思考为什么不直接使用toString()方法呢?
因为toString为Object的原型方法,而Array ,function等类型作为Object的实例,都重写了toString方法,示例如下:

let array =  [1,2,3];

arr.toString(); // 已经被重写输出:1,2,3 
Object.prototype.toString.call(arr); // 最原始的输出:"[object Array]"

总结

instanceof和constructor有原型链断裂的风险,Object.prototype.toString.call()最稳定。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
4318
获赞与收藏
1744

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消