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()只能判断是否为数组类型,使用简单且语义清晰。
相关推荐
weixin_4316004420 分钟前
使用 Vue Tour 封装一个统一的页面引导组件
javascript·vue.js·ecmascript
鸡吃丸子1 小时前
常见的实时通信技术(轮询、sse、websocket、webhooks)
前端·websocket·状态模式
胡斌附体1 小时前
vue添加loading后修复页面渲染问题
前端·javascript·vue.js·渲染·v-if·异步加载
Dontla1 小时前
Webpack DefinePlugin插件介绍(允许在编译时创建JS全局常量,常量可以在源代码中直接使用)JS环境变量
运维·javascript·webpack
酷爱码2 小时前
css中的 vertical-align与line-height作用详解
前端·css
沐土Arvin2 小时前
深入理解 requestIdleCallback:浏览器空闲时段的性能优化利器
开发语言·前端·javascript·设计模式·html
专注VB编程开发20年2 小时前
VB.NET关于接口实现与简化设计的分析,封装其他类
java·前端·数据库
小妖6663 小时前
css 中 content: “\e6d0“ 怎么变成图标的?
前端·css
L耀早睡3 小时前
mapreduce打包运行
大数据·前端·spark·mapreduce
咖啡の猫3 小时前
JavaScript基础-创建对象的三种方式
开发语言·javascript·ecmascript