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",无法区分数组、日期、正则等:
立即学习“Java免费学习笔记(深入)”;
-
typeof []→"object" -
typeof new Date()→"object" -
typeof /test/→"object"(某些环境是"regexp",但不可靠)
而 instanceof 可以精准识别这些内置构造器的实例,前提是运行时环境中有对应的构造函数且未被篡改。
注意跨 iframe 或不同全局环境的问题
每个 iframe 或 Worker 有自己的全局执行上下文,因此各自的 Array、Object 等构造函数是不同的引用:
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
它能正确反映继承关系,是判断实例归属最直观的方式之一。











