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
它能正确反映继承关系,是判断实例归属最直观的方式之一。
以上就是javascript instanceof运算符是什么_如何检查对象的类型?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1544676.html
微信扫一扫
支付宝扫一扫