Object.prototype.toString.call() 和 instanceOf 和 Array.isArray() 区别以及优缺点

Object.prototype.toString.call()、instanceof和Array.isArray()都是判断数据类型的方法,但在具体的使用上有一些区别和优缺点。

  1. Object.prototype.toString.call(): Object.prototype.toString.call(obj)方法可以获取obj的类型。对于原始类型,返回结果如下:
  • 数字类型返回 "[object Number]"
  • 字符串类型返回 "[object String]"
  • 布尔类型返回 "[object Boolean]"
  • undefined返回 "[object Undefined]"
  • null返回 "[object Null]"

对于引用类型,返回结果如下:

  • 对象类型返回 "[object Object]"
  • 数组类型返回 "[object Array]"
  • 函数类型返回 "[object Function]"
  • Date类型返回 "[object Date]"
  • RegExp类型返回 "[object RegExp]"
  • ...

优点:

  • 可以准确判断各种类型,包括引用类型和原始类型。

缺点:

  • 使用起来较为繁琐,需要通过Object.prototype.toString.call(obj)来获取类型。

示例代码:

javascript 复制代码
var obj = {};
var arr = [];

console.log(Object.prototype.toString.call(obj)); // [object Object]
console.log(Object.prototype.toString.call(arr)); // [object Array]
  1. instanceof: instanceof是一种运算符,判断一个对象是否是某个构造函数创建的实例。语法是 obj instanceof constructor。如果obj是constructor的实例,返回 true;否则返回 false。

优点:

  • 使用简单,语义清晰。

缺点:

  • 只能判断对象是否是某个构造函数的实例,不能判断具体的类型。

示例代码:

javascript 复制代码
var obj = {};
var arr = [];

console.log(obj instanceof Object); // true
console.log(arr instanceof Array); // true
  1. Array.isArray(): Array.isArray(obj)方法用来判断obj是否为数组类型。

优点:

  • 使用简单,语义清晰。

缺点:

  • 只能判断是否为数组类型。

示例代码:

javascript 复制代码
var obj = {};
var arr = [];

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

综合比较:

  • Object.prototype.toString.call()最为全面,可以判断各种类型,但使用起来较为繁琐。
  • instanceof只能判断对象是否是某个构造函数的实例,使用简单但不能判断具体类型。
  • Array.isArray()只能判断是否为数组类型,使用简单且语义清晰。
相关推荐
candyTong2 小时前
一觉醒来,大模型就帮我排查完页面性能问题
前端·javascript·架构
魔术师Grace2 小时前
我给 AI 做了场入职培训
前端·程序员
玩嵌入式的菜鸡2 小时前
网页访问单片机设备---基于mqtt
前端·javascript·css
前端一小卒3 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
滑雪的企鹅.4 小时前
HTML头部元信息避坑指南大纲
前端·html
一拳不是超人4 小时前
老婆天天吵吵要买塔罗牌,我直接用 AI 2 小时写了个在线塔罗牌
前端·ai编程
excel6 小时前
如何解决 Nuxt DevTools 中关于 unstorage 包的报错
前端
Rust研习社6 小时前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
C澒6 小时前
AI 生码 - API2Code:接口智能匹配与 API 自动化生码全链路设计
前端·低代码·ai编程
浔川python社6 小时前
HTML头部元信息避坑指南技术文章大纲
前端·html