彻底理解什么是原型链,prototype和__proto__的区别,以及手写实现instanceof关键字

1.Javascript中所有的对象都是Object的实例,并继承Object.prototype的属性和方法,也就是说,Object.prototype是所有对象的爸爸。(重点!!!)

2.定义函数的时候,预定义属性就是prototype,这个prototype是一个普通的对象。

而定义普通的对象的时候,就会生成一个__proto__,这个__proto__指向的是这个对象的构造函数的prototype.

3.反正根据上文两个要点,可以整理得:

例如我们定义一个函数

functon fun(a){
     console.log(a)
}

那么这个函数本身就因为函数的定义而有一个prototype,然后这个函数的_proto_就是Object.prototype

然后使用这个函数去定义一个实例的时候:

fun(""laozhichi love liulijuan)

那么这个已经实例化的函数的_proto_就指向了其定义时函数的prototype

4.所以根据前面几点的介绍,当我们手写实现prototype关键字的时候,可以使用以下代码:

function instanceOf(father, child) {
    const fp = father.prototype
    var cp = child.__proto__   //在这里的_proto_表示指向上一级的

    while (cp) {
        if (cp === fp) {
            return true
        }
        cp = cp.__proto__
    }

    return false
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值