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()只能判断是否为数组类型,使用简单且语义清晰。
相关推荐
沉登c1 分钟前
Javascript客户端时间与服务器时间
服务器·javascript
持久的棒棒君4 分钟前
ElementUI 2.x 输入框回车后在调用接口进行远程搜索功能
前端·javascript·elementui
2401_8572979114 分钟前
秋招内推2025-招联金融
java·前端·算法·金融·求职招聘
undefined&&懒洋洋1 小时前
Web和UE5像素流送、通信教程
前端·ue5
大前端爱好者3 小时前
React 19 新特性详解
前端
小程xy3 小时前
react 知识点汇总(非常全面)
前端·javascript·react.js
随云6323 小时前
WebGL编程指南之着色器语言GLSL ES(入门GLSL ES这篇就够了)
前端·webgl
随云6323 小时前
WebGL编程指南之进入三维世界
前端·webgl
寻找09之夏4 小时前
【Vue3实战】:用导航守卫拦截未保存的编辑,提升用户体验
前端·vue.js
非著名架构师4 小时前
js混淆的方式方法
开发语言·javascript·ecmascript