javascript instanceof运算符是什么_如何检查对象的类型?

instanceof 是 JavaScript 中用于检测对象是否为某构造函数实例的运算符,通过检查对象原型链是否包含 Constructor.prototype 返回布尔值;仅适用于对象,对原始值返回 false,可区分引用类型但受跨全局环境限制。

instanceof 是 JavaScript 中用于检测一个对象是否为某个构造函数(或类)的实例的运算符。它不看变量值本身,而是检查对象的原型链上是否存在该构造函数的 prototype 对象。

instanceof 的基本用法

语法是:object instanceof Constructor,返回布尔值。

  • 如果 object 的原型链中能找到 Constructor.prototype,结果为 true
  • 否则为 false
  • 只能用于对象,对原始值(如字符串、数字、布尔)直接使用会返回 false

例如:

const arr = [1, 2, 3];
console.log(arr instanceof Array);     // true
console.log(arr instanceof Object); // true(Array 原型链上有 Object.prototype)
console.log('hello' instanceof String); // false(字面量字符串不是 String 实例)
console.log(new String('hello') instanceof String); // true

为什么不能只靠 typeof 判断对象类型?

typeof 对大部分引用类型都返回 "object",无法区分数组、日期、正则等:

  • typeof []"object"
  • typeof new Date()"object"
  • typeof /test/"object"(某些环境是 "regexp",但不可靠)

instanceof 可以精准识别这些内置构造器的实例,前提是运行时环境中有对应的构造函数且未被篡改。

注意跨 iframe 或不同全局环境的问题

每个 iframe 或 Worker 有自己的全局执行上下文,因此各自的 ArrayObject 等构造函数是不同的引用:

  • iframe.contentWindow.Array !== Array
  • 在父页面创建的数组,用子页面的 Array 检测会返回 false

这种情况下推荐用 Array.isArray()Object.prototype.toString.call() 等更健壮的方法替代 instanceof

和 class、自定义构造函数一起用

ES6 class 和传统构造函数一样支持 instanceof

class Animal {}
class Dog extends Animal {}
const dog = new Dog();
console.log(dog instanceof Dog);    // true
console.log(dog instanceof Animal); // true
console.log(dog instanceof Object); // true

它能正确反映继承关系,是判断实例归属最直观的方式之一。