数组判断?我早不用instanceof了,现在一行代码搞定!

传统方案

1. Object.prototype.toString.call 方法

原理 :通过调用 Object.prototype.toString.call(obj) ,判断返回值是否为 [object Array]

js 复制代码
function isArray(obj){
  return Object.prototype.toString.call(obj) === '[object Array]';
}

缺陷

  • ES6 引入 Symbol.toStringTag 后,可被人为篡改。例如:

    js 复制代码
    const obj = {
      [Symbol.toStringTag]: 'Array'
    };
    console.log(Object.prototype.toString.call(obj)); // 输出 [object Array]
  • 若开发通用型代码(如框架、库),该漏洞会导致判断失效。

2. instanceof 方法

原理 :判断对象原型链上是否存在 Array 构造函数。

js 复制代码
function isArray(obj){
  return obj instanceof Array;
}

缺陷

  • 可通过 Object.setPrototypeOf 篡改原型链,导致误判。例如:

    js 复制代码
    const obj = {};
    Object.setPrototypeOf(obj, Array.prototype);
    console.log(obj instanceof Array); // 输出 true,但 obj 并非真正数组
  • 跨 iframe 场景失效。不同 iframe 中的 Array 构造函数不共享,导致真数组被误判为非数组。例如:

    js 复制代码
    const frame = document.querySelector('iframe');
    const Array2 = frame.contentWindow.Array;
    const arr = new Array2();
    console.log(arr instanceof Array); // 输出 false,但 arr 是真正数组

ES6 原生方法

方法 :使用 Array.isArray 静态方法。

js 复制代码
console.log(Array.isArray(arr));

优势

  • 该方法由JavaScript引擎内部实现,直接判断对象是否由 Array 构造函数创建,不受原型链、 Symbol.toStringTag 或跨 iframe 影响;

  • 完美解决所有边界场景。

总结

判断数组的方法中 Array.isArray 是唯一准确且无缺陷的方案。其他方法(如Object.prototype.toString.callinstanceof)均存在局限性,仅在特定场景下可用。

相关推荐
NiceCloud喜云6 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby6 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
GISer_Jing6 小时前
Three.js着色器编译机制深度解析
javascript·webgl·着色器
丷丩6 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
油炸自行车6 小时前
Claude Code 错误:API Error: 400 Failed to deserialize the JSON body into the
开发语言·javascript·json·trae·claude code·api error 400
Front思7 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫9 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。10 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星10 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒11 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端