再也不怕面试官问什么是 instanceof 了

来看看今天的链式问题:

  1. 作用是啥?
  2. 原理是啥?
  3. 怎么实现?
  4. 源码实现

instanceof 解决什么问题

我们在使用 instanceof 的时候,需要知道,它是用来判断某实例是否是特定的类型。什么意思呢?

  1. 首先,我们在使用 typeof 的时候,只能判断基础数据类型,当判断引用数据类型的时候呢,无论什么类型的变量,都会返回 Object
  2. 所以这里引入了 instanceof 来判断引用数据类型。
  3. instanceof 运算符可以用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

来看看语法:

// object 某个实例对象
// constructor 某个构造函数
object instanceof constructor

那我们就可以理解为:instanceof 运算符用来检测 constructor.prototype 是否存在于参数 obejct 的原型链上。

// 定义构造函数
function C(){}
function D(){}

var o = new C();

o instanceof C; // true
o instanceof D; // false
o instanceof Object; // true

实现原理是什么?

instanceof 的内部实现机制是:通过判断参数对象的原型链上是否能找到构造函数prototype,来确定 instanceof 的返回值。

我们可以使用 Object.getPrototypeOf(obj) 来判断是否等于构造函数的 prototype;也可以使用 Object.prototype.isPrototypeOf(obj) 返回值来判断,比如上述例子:

o instanceof C; // true  
// Object.getPrototypeOf(o) === C.prototype

o instanceof Object; // true
// Object.prototype.isPrototypeOf(o) 返回 true

当然我们也可以使用其他方法来实现:

function instance_of(obj, cons) {
  var consPrototype = cons.prototype;

  var objProrotype = obj.__proto__;

  while(true) {
    if (objProrotype === null) {
      return false;
    }

    if (consPrototype === objProrotype) {
      return true
    }

    // 原型链向上查找
    objProrotype = objProrotype.__proto__;
  }
}

怎么实现?

那根据上述所讲,我们自己去实现一个 instanceof 方法,有三种方式:

  1. Object.getPrototypeOf(obj)——返回指定对象的原型(内部 [[Prototype]] 属性的值)
  2. Object.prototype.isPrototypeOf(obj)——测试一个对象是否存在于另一个对象的原型上
  3. obj.__proto__——使用非标准的 __proto__ 的伪属性

源码实现

  1. 使用 Object.getPrototypeOf(obj)
    function instance_of(o, c) {
      let op = Object.getPrototypeOf(o);
      const cp = c.prototype;
    
     while(true) {
       if (!op) {
         return false
       } 
    
       if (op === cp) {
         return true
       }
    
       op = Object.getPrototypeOf(op);
     }
    }
    
  2. Object.prototype.isPrototypeOf(obj)
    function instance_of(o, c) {
      return c.prototype.isPrototypeOf(o);
    }
    
  3. obj.__proto__
    function instance_of(o, c) {
      let op = o.__proto__;
      const cp = c.prototype;
    
      while(true) {
        if (op === null) {
          return false
        }
    
        if (op === cp) {
          return true
        }
    
        op = op.__proto__;
      }
    }
    

公众号:Coder 杂谈,欢迎关注
在这里插入图片描述
原博文地址:https://hsx33.gitee.io/hsxblog/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值