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()只能判断是否为数组类型,使用简单且语义清晰。
相关推荐
学嵌入式的小杨同学17 分钟前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543731 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_2 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得02 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~2 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
yuezhilangniao2 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
不绝1913 小时前
UGUI——进阶篇
前端
Exquisite.3 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
铅笔侠_小龙虾3 小时前
Flutter Demo
开发语言·javascript·flutter
2501_944525543 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter