码迷,mamicode.com
首页 > Web开发 > 详细

关于js中的原型

时间:2016-04-03 20:09:43      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:

我们知道无论什么时候只要创建了一个函数,就会为该函数创建一个prototype属性,这个属性指向函数的原型对象,默认情况下所有原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含了一个指向prototype属性所在函数的指针。当调用构造函数创建一个新实例后,该实例内部就会包含一个[[prototype]]指针(内部属性),指向构造函数的原型对象。例如以下的代码:

 

    function Person(){
    }
    Person.prototype.name = "pan";
    Person.prototype.age = 23;
    };
    var person1 = new Person();

 

这段代码中Person构造函数、Person的原型属性以及Person的现有实例person之间的关系可以用下图来表示:

技术分享

在这里,Person.prototype指向了原型对象,而Person.prototype.constructor又回指了Person。实例person1包含了一个指向Person.prototype的内部属性[[Prototype]]。

现在来看看我们上面的图是否说对了呢?

    function Person(){
    }
    Person.prototype.name = "pan";
    Person.prototype.age = 23;
    var person1 = new Person();
    console.log(Person.prototype);
    console.log(person1.__proto__);
    console.log(Person.prototype.constructor);
    console.log(person1.__proto__.constructor);
    console.log(person1.name);

技术分享

 

 

 

 

 

 

 

我们可以看到Person.prototype与person1.__proto__都是同一个对象Person{},所以Person.prototype.constructor和person1.__proto__.constructor都是Person这个函数。又因为person1可以利用原型链向上查找到Person.prototype的属性并使用,所以person1.name的值为pan。

 

关于js中的原型

标签:

原文地址:http://www.cnblogs.com/pwei/p/js-prototype.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!