日期:2014-05-16  浏览次数:20382 次

Javascript中的__proto__、prototype、constructor

今天重温了下Javacript,给大家带来一篇Javascript博文,相信对于Javacript有一定了解的人都听过prototype原型这个概念,今天我们深度的分析下prototype与__proto__。

好了,下面看一个非常简单的例子:

      var Person = function(name)
       {
           this.name = name ;
       };
      var p = new Person("Ben");
      console.log(p.name);
代码简单的 你不用说明了,如果现在让大家根据上面的代码画一张包含Function与Object的内存图,大家肯定回想什么叫包含Function与Object,上面的代码和它们有几毛钱的关系。好了,下面我先按要求把图画出来,大家参考下:


解析下:

1、任何一个由构造器产生的对象都有__proto__属性,且此属性指向该构造器的prototype。

2、所有构造器/函数的__proto__都指向Function的prototype

拿第2条对比第1条,貌似我们发现了什么,没错函数的构造器就是Function,看下面的代码:

   //函数表达式
       var Person = function(name)
       {
           this.name = name ;
       };
        //函数声明
        function Person(name)
        {
            this.name = name ;
        }
        //上面两种方式实际上就相当与new Function
        var Person = new Function("name" , "this.name = name ;" );
当然了不能说说,下面看代码验证:

 console.log(Person.__proto__ === Function.prototype);  //true
 console.log(typeof p.__proto__);//objcect
 console.log(p.__proto__.__proto__ === Object.prototype); //true

有人会问,那么Function与Object的prototype,__prop__到底是什么呢?

     console.log(Object.__proto__ === Function.prototype); // true
        console.log(Function.__proto__ === Function.prototype); //true
        console.log(Function.prototype.__proto__ == Object.prototype); //true
        console.log(Object.prototype.__proto__); //null


有此可见

1、所有的构造器包括Object和Function都继承了Function.prototype的方法,由第三行可知所有的构造器都是对象,即js中一切皆为对象。

2、__proto__最终的指向都是Object.prototype,这也就是js中的原型链。


最后我们看一下Object的文档:

Properties

The following table lists properties of the Object Object.

Property