【无标题】

总结

  1. Array.isArray(obj) ✅ 推荐
  2. obj instanceof Array
  3. Object.prototype.toString.call(obj) === '[object Array]'
  4. Array.prototype.isPrototypeOf(obj)

方法对比

方法 是否推荐 说明
Array.isArray(obj) ✅ 强烈推荐 最直接、最准确的方式
obj instanceof Array ✅ 推荐 适用于单一全局环境,跨框架可能出错
Object.prototype.toString.call(obj) ✅ 推荐 可靠的通用方法,适用于所有对象类型判断
Array.prototype.isPrototypeOf(obj) ❌ 不推荐 判断的是原型链,不能准确判断是否为数组实例

示例代码

1. Array.isArray()

js 复制代码
const arr = [1, 2, 3];
console.log(Array.isArray(arr)); // true

const obj = {};
console.log(Array.isArray(obj)); // false

2. instanceof Array

js 复制代码
const arr = [1, 2, 3];
console.log(arr instanceof Array); // true

const obj = {};
console.log(obj instanceof Array); // false

⚠️ 注意:instanceof 在跨框架(如 iframe)时可能返回 false

3. Object.prototype.toString.call()

js 复制代码
const arr = [1, 2, 3];
console.log(Object.prototype.toString.call(arr)); // [object Array]

const obj = {};
console.log(Object.prototype.toString.call(obj)); // [object Object]

这是最通用、最安全的类型判断方式,适用于任何 JavaScript 环境。

4. Array.prototype.isPrototypeOf()

js 复制代码
const arr = [1, 2, 3];
console.log(Array.prototype.isPrototypeOf(arr)); // true

const obj = {};
console.log(Array.prototype.isPrototypeOf(obj)); // false

⚠️ 此方法判断的是原型链关系,并非是否为数组实例,不推荐用于判断数组。

推荐用法

  • 优先使用 Array.isArray():简洁、准确、标准。
  • 次选 Object.prototype.toString.call():适用于需要兼容旧环境或判断多种类型时。

注意事项

  • 避免使用 typeof 判断数组:typeof [] 返回 "object"
  • 避免使用 instanceof 在跨全局对象(如多个 window)的场景中使用。

相关推荐
GalaxyPokemon13 分钟前
Linux的pthread怎么实现的?(包括到汇编层的实现)
运维·开发语言·c++
凉_橙18 分钟前
什么是抽象语法树?
前端·javascript
页面魔术21 分钟前
尤雨溪: 我们没有放弃虚拟 dom
前端·javascript·vue.js
lsx20240625 分钟前
Ruby 条件判断
开发语言
臻实31 分钟前
Win10系统Ruby+Devkit3.4.5-1安装
开发语言·后端·ruby
IT毕设实战小研39 分钟前
Java毕业设计选题推荐 |基于SpringBoot的水产养殖管理系统 智能水产养殖监测系统 水产养殖小程序
java·开发语言·vue.js·spring boot·毕业设计·课程设计
Hilaku1 小时前
深入理解npm、pnpm和yarn的lock文件,我发现了一些细节
前端·javascript·npm
Gu_shiwww1 小时前
数据结构3线性表——单链表(C)
c语言·开发语言·数据结构
Juchecar1 小时前
不用打包工具,直接采用 Vue + Express 的代码示例
javascript
Juchecar1 小时前
基于 Nuxt 3 前后端均采用 TS/JS 实现界面交互的完整代码示例
javascript