JS 原型链

   在正文以前,首先要知道两点,函数

  一、__proto__是每一个js 对象的内置属性,而prototype 是函数的内置属性,也是一个对象。spa

  二、所谓原型,指的就是每一个函数对象的prototype属性。prototype

function A(){
}
var a = new A();

  A是一个函数,因此A.prototype(A的原型)是存在的(这个指向的是一个对象),而a.prototype 是不存在的,如下开始正文。3d

  带着以上几个问题,开始向下扯这条原型链。code

 var a = new A();

  因为a是由new A 产生的,因此a和A之间应该有个什么东西保持一下关系,怎么办呢,那么咱们就给a添加一个__proto__属性吧,这个东西怎么用呢?把它指向A自己?对象

  A确定不肯意,A以为:你是由我产生的,还想把我变成你的一个属性?没大没小的,不能这么干,因而A想了一个办法,你就指向个人原型(prototype)属性吧,之后你出去混只要说你的__proto__ 和个人原型同样,证实你就是个人小弟,是个人一个实例。因而就有了,blog

  

a.__proto__ == A.prototype //true

 有的人可能就会问,A也是一个对象,他也应该有本身的__proto__的吧,A的老大是谁?原型链

 这个问题问得好,要搞明白这个,先得了解A 是怎么产生的,原型

  

function A(){
}

  找到了,就是这么来的,A 是function 定义出来的,貌似不是new 出来的啊,咋找呢?其实这个function a(){}只是一个语法糖而已,实际上等价于博客

var A = new Function()

原来如此,觉得穿了个马甲我就不认识你了?这样一来很清楚了,

A.__proto__ == Function.prototype //true

   好奇的同窗又会问了,A的原型(A.prototype)说了半天,他是什么呢??这位同窗,你怎么这么多问题?看在你骨骼惊奇,咱们就来研究研究,向万能的控制台问一问。

看见了吧,A.prototype是一个Object,自带constructor属性,这个constructor指向哪里?

原来是他本身,这个constructor咱们叫他构造函数。指向的是函数自己。

 那么A.prototype.__proto__又指向啥啊?哇塞,好饶人哦!!!

一样,搞清楚__proto__是啥,就得知道A.protoype是啥,从哪里来,显然,A.prototype是一个对象,对象的老大是谁,off course !!! 全部对象的老大都是Object ,实际上全部的对象都是new Object()出来的,你觉得var B = {} 这种不是?其实也是个语法糖而已。其实是:

var B = new Object();

 

 因此又有

A.prototype.__proto__ == Object.prototype  // true

(看到这里,一、2,问题应该有些了解了吧)

  聪明的小朋友可能发现了,new Object() 这个是说明Object 也是一个函数吧!恭喜答对,明年就你当班长了!

既然也是一个函数,因此有:

Object.__proto__ == Function.prototype //true

那么 Function 是谁产生的呢?想起来没new Function()这种写法,因此Function 自己也是一个函数,因此有

Function.__proto__ == Function.prototype

握草,有点懵逼!!!(此处应有十脸懵逼表情包),虽然他们的关系有点乱,可是这就是他们,晕了没,晕的话下面还有哦,

爱问问题的小朋友又提问啦!惊喜不?Function.prototype.__proto__是谁?

显然,Function.prototype 是一个对象,因此,

Function.prototype.__proto__ == Object.prototype //true

好吧,我保证这是最后一个问题!!Object.prototype.__proto__是谁???

  老师我知道!聪明的小朋友可能会以为,Object.prototype也是一个对象,因此应该就是Object.prototype !,错!

是null,记住了哦!

 

 

 

 

 

 

 

 

注:本文出自博客园http://www.cnblogs.com/mdengcc/ 转载请注明出处。

相关文章
相关标签/搜索