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()只能判断是否为数组类型,使用简单且语义清晰。
相关推荐
m0_748251729 分钟前
前端入门之VUE--ajax、vuex、router,最后的前端总结
前端·vue.js·ajax
上等猿12 分钟前
Ajax笔记
前端·笔记·ajax
Amo 672914 分钟前
css 编写注意-1-命名约定
前端·css
匹马夕阳20 分钟前
详细对比JS中XMLHttpRequest和fetch的使用
开发语言·javascript·ecmascript
长风清留扬1 小时前
小程序开发实战项目:构建简易待办事项列表
javascript·css·微信小程序·小程序·apache
程序员_三木1 小时前
从 0 到 1 实现鼠标联动粒子动画
javascript·计算机外设·webgl·three.js
点点滴滴的记录1 小时前
Java的CompletableFuture实现原理
java·开发语言·javascript
程序猿online1 小时前
nvm安装使用,控制node版本
开发语言·前端·学习
web Rookie1 小时前
React 中 createContext 和 useContext 的深度应用与优化实战
前端·javascript·react.js
男孩121 小时前
react高阶组件及hooks
前端·javascript·react.js