instanceof的原理是什么?手写instanceof方法

2024-03-26 03:20

本文主要是介绍instanceof的原理是什么?手写instanceof方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

instanceof 的含义

instanceof 运算符 是 JavaScript 中用于检测 一个对象 是否是其构造函数的 prototype 属性指向的原型链上的实例。
(简单记:用于检查一个对象是否是指定构造函数的 prototype 原型链上的实例。)

实现思路

输入一个对象,一个构造函数;通过循环遍历对象的原型链,逐级检查是否与给定构造函数的原型相匹配,从而判断对象是否是由特定构造函数创建的。

核心代码

function myInstanceOf(obj, constructor) {if (typeof constructor !== "function" || constructor === null) {throw new Error("类型输入错误");}let proto = Object.getPrototypeOf(obj); // 获取obj的原型,相当于obj.__proto__while (proto) { // 循环检查原型链,直到原型链的末端 Object.prototype 或 nullif (proto === constructor.prototype) { // 如果找到匹配的构造函数,返回 truereturn true;}proto = Object.getPrototypeOf(proto); // 继续向上查找原型,相当于proto.__proto__;}return false;
}
// 使用示例  
function MyObject() {}  
const obj = new MyObject();  
console.log(myInstanceOf(obj, MyObject)); // 输出: true  
console.log(myInstanceOf(obj, Array));    // 输出: false

这个实现假设所有对象都是通过 new 关键字创建的,并且它们的原型链最终会指向 null 或 Object.prototype。
判断条件只要求输入object类型时,判断条件改为:

// 如果 object 不是对象,返回 false  
if (typeof object !== 'object' || object === null) {  return false;  
} 

测试结果:

console.log('typeof Object:',typeof Object) // function
console.log('1'.constructor)
console.log([].constructor)
console.log({}.constructor)

控制台运行结果:

typeof Object: function
instancesOf的实现.html:50 ƒ String() { [native code] }
instancesOf的实现.html:51 ƒ Array() { [native code] }
instancesOf的实现.html:52 ƒ Object() { [native code] }

补充知识:Object.getPrototypeOf()

Object.getPrototypeOf(xx),用于获取指定对象的原型(即原型链的上一层对象),相当于xx.proto,查找xx的原型

console.log(Object.getPrototypeOf(Object.prototype) === null); // true
const array = [];
console.log(array.__proto__ === Array.prototype) // __proto__指向其构造函数的prototype属性, true
console.log(Object.getPrototypeOf(array) === Array.prototype); // trueconst date = new Date();
console.log(Object.getPrototypeOf(date) === Date.prototype); // true

这篇关于instanceof的原理是什么?手写instanceof方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/847132

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱