JavaScript instanceof:你真的懂它吗?

什么是 instanceof

instanceof 运算符用于检测构造函数的 prototype 属性是否出现在对象的原型链中的任何位置。简单来说,它判断一个对象是否是某个构造函数的实例。

语法:

javascript 复制代码
object instanceof constructor
  • object: 要检测的对象。
  • constructor: 构造函数。

返回值:

  • 如果 objectconstructor 的实例,则返回 true
  • 否则,返回 false

示例:

javascript 复制代码
function Person(name) {
  this.name = name;
}

const person = new Person("Alice");

console.log(person instanceof Person); // true
console.log(person instanceof Object); // true (因为 Person 的原型链最终指向 Object)
console.log(person instanceof Array);  // false

instanceof 对比 typeof

typeof 只能区分基本数据类型(string, number, boolean, undefined, symbol)和 object。对于对象类型,typeof 只能返回 object,无法区分是数组、日期、还是自定义对象。而 instanceof 可以更精确地判断对象的类型,因为它会沿着原型链向上查找。

javascript 复制代码
const arr = [];
const date = new Date();

console.log(typeof arr);  // object
console.log(typeof date); // object
console.log(typeof null); // object (这是一个历史遗留问题,需要注意)

instanceof 的工作原理:原型链的秘密

instanceof 的核心在于原型链。每个 JavaScript 对象都有一个指向其原型的链接,这个原型本身也是一个对象,也有自己的原型,以此类推,形成一个原型链。

当使用 instanceof 运算符时,JavaScript 引擎会:

  1. 获取 constructorprototype 属性。
  2. 沿着 object 的原型链向上查找。
  3. 如果找到与 constructor.prototype 相等的原型,则返回 true
  4. 如果直到原型链的顶端(null)都没有找到,则返回 false

手写一个 myInstanceOf 函数:

为了更好地理解 instanceof 的工作原理,我们可以尝试手写一个类似的函数:

javascript 复制代码
function myInstanceOf(obj, constructor) {
  if (typeof obj !== 'object' || obj === null) {
    return false; // 基本类型和 null 不是任何构造函数的实例
  }

  let proto = Object.getPrototypeOf(obj); // 获取对象的原型

  while (proto) {
    if (proto === constructor.prototype) {
      return true;
    }
    proto = Object.getPrototypeOf(proto); // 继续向上查找原型链
  }

  return false; // 没有找到
}

function Person(name) {
  this.name = name;
}

const person = new Person("Alice");

console.log(myInstanceOf(person, Person)); // true
console.log(myInstanceOf(person, Object)); // true
console.log(myInstanceOf(person, Array));  // false
相关推荐
雨汨8 分钟前
el-input限制输入数字,输入中文后数字校验失效
前端·javascript·vue.js
保持学习ing14 分钟前
帝可得- 人员管理
前端·vue.js·elementui
一嘴一个橘子14 分钟前
el-table 树形数据,子行数据可以异步加载
javascript·elementui
難釋懷15 分钟前
Vue全局事件总线
前端·javascript·vue.js
生产队队长15 分钟前
项目练习:element ui 的icon放在button的右侧
开发语言·javascript·ui
独立开阀者_FwtCoder29 分钟前
使用这个新的 ECMAScript 运算符告别 Try/Catch!
前端·javascript·github
云浪29 分钟前
让元素舞动!深度解密 CSS 旋转函数
前端·css
cdcdhj30 分钟前
vue中events选项与$on监听自定义事件他们的区别与不同,以及$emit与$on之间通信和mounted生命周期钩子函数有哪些作用和属性
前端·javascript·vue.js
Jinxiansen021142 分钟前
Vue 3 弹出式计算器组件(源码 + 教程)
前端·javascript·vue.js
东京老树根1 小时前
SAP学习笔记 - 开发22 - 前端Fiori开发 数据绑定(Jason),Data Types(数据类型)
前端·笔记·学习