js的原型链和constructor

 

 

转载:http://www.108js.com/article/article1/10201.html?id=1092javascript

请先瞻仰上边的这篇文章。html

对象的原型链:java

box.__proto__.__proto__ == Object.prototype函数

//truethis

上边对象的__proto__的属性讨论完了,咱们来看函数。prototype

person3d

普通函数的__proto__属性:htm

person.__proto__ == Function.prototype //true对象

person.__proto //function(){}blog

box.__proto__ == person.prototype //true 这个是确定的。

box.__proto__这个也是一个对象,这个对象的__proto__属性是什么呢

box.__proto__.__proto__ == Object.prototype//true 

下边咱们来讨论Function.prototype 和Object.prototype的理解

Object.prototype 

Function.prototype //function(){}

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

Function.prototype === Object.prototype  //false
下边的一段话,咱们能够看到:

  1. javascript中,“函数”(方法)也是对象。

  2. 一切对象都有一个根源。它是Object.prototype。

  3. 根源之上再没有其余根源。Object.getPrototypeOf(Object.prototype)是null。js中除字面量之外的一切引用对象都来自这个“根源”对象。

  4. 表达式Object.getPrototypeOf(Function) === Function.prototype的结果是真。这是Function特有的。实际上Function的prototype是一个内置函数,一切函数都派生自这个内置函数,这个内置函数是一个函数工厂。这个内置函数对象的prototype指向“根源”对象。

  5. 表达式Object.prototype === Object.getPrototypeOf(Function.prototype)的结果是真。说明了Object跟Function两者之间的联系,是经过“根源”对象联系起来的。

    Function和Object,既是函数,由于均可以Function()或者Object()这样的方式执行,又是对象,由于能够Function.a = 'a',Object.a = 'a'这样赋值。

     

    说它们是函数,是由于他们都是经过上面第4条中说的”内置函数工厂“,派生出来的,于是具有函数的特性。

     

    说他们是对象。是由于他们都是经过上面第1条中的”根源“对象,派生出来的,所以具有对象的特征。

     

    继续说一下,Function.prototype指向”内置函数“。而Object.prototype指向”根源对象“。

    于是new Function会产生一个匿名函数,而new Object产生一个plain object。

     

    他们之间的关系简单描述就像下面这样。

 ===================================================================== 

constructor

何时function会变为构造器呢?

当方法的返回值为this的时候,或者说默认的返回值就是this.

当方法的返回值是匿名函数的时候,function就再也不是匿名 函数

另外一种状况返回this,或者不返回的时候:

 

 

相关文章
相关标签/搜索