js原型与原型链完整图解

首先要知道:

1、所有对象(除null)都有一个__proto__属性指向构造函数的原型对象

2、所有对象(除null)都有一个constructor属性指向构造函数(函数也是对象)

已知:有一个构造函数Fn,并通过Fn new出一个实例fn

即:

      function Fn(){}

      var fn = new Fn()

然后就能画出如下的原型图

其中红色和蓝色线条分别表示两条原型链(__proto__形成的链式结构)

 

 注:

1、Function的constructor还是指向Function,Function的__proto__属性指向Function的原型(紫色线条)

所以:

Function===Function.constructor (无论多少个constructor都等于Function)

Function.constructor===Function.constructor.constructor

Function.prototype === Function.__proto__

2、写这篇只是当笔记,每次好不容易搞懂,过几个月又忘记了,干脆自己画个图,下次可以回忆得快点。 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值