区分 JavaScript 中的 Array 和 Object 有四种方法:Array.isArray() 方法直接检查变量是否为数组。instanceof 运算符检查变量是否为 Array 实例。Object.prototype.toString.call() 方法返回数组的类型描述符。数组具有 length 属性,而对象没有。

如何用 JavaScript 区分 Array 和 Object
简介
在 JavaScript 中,Array 和 Object 是两种数据结构,用于存储和整理数据。尽管它们具有相似之处,但它们本质上还是不同的数据类型,在某些情况下需要加以区分。
区分方法
1. Array.isArray() 方法:
- 用于直接检查变量是否是 Array,返回布尔值。
2. instanceof 运算符:
- 检查变量是否为 Array(或任何其他类)的实例。
3. Object.prototype.toString.call() 方法:
- 返回对象的类型描述符,对于数组会返回 "[object Array]"。
4. 检查对象是否具有 length 属性:
- 数组具有 length 属性,而对象没有。
详细说明
JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合于服务器与 JavaScript 的交互。本文将快速讲解 JSON 格式,并通过代码示例演示如何分别在客户端和服务器端进行 JSON 格式数据的处理。
Array.isArray() 方法:
let arr = [1, 2, 3]; console.log(Array.isArray(arr)); // true
instanceof 运算符:
let arr = [1, 2, 3]; console.log(arr instanceof Array); // true
Object.prototype.toString.call() 方法:
let arr = [1, 2, 3]; console.log(Object.prototype.toString.call(arr)); // "[object Array]"
检查 length 属性:
let arr = [1, 2, 3];
console.log(arr.hasOwnProperty("length")); // true
let obj = { name: "John" };
console.log(obj.hasOwnProperty("length")); // false要注意的特殊情况
- 继承自 Array 的自定义对象或类也可以通过 Array.isArray() 和 instanceof 检查。
- 类似地,某些库或框架可能会提供类似于 Array 的对象,因此使用 Object.prototype.toString.call() 方法可能更可靠。









