首页 > 代码库 > 原型、原型链

原型、原型链

  原型和原型链的了解和掌握

   在学习原型和原型链的时候有一点费劲,对我第一次学习来说有点绕。所以,今天来给大家说一下:

   原型是什么

   原型是一个对象,其他对象可以通过它实现属性继承。

   每一个对象都有一个属性叫prototype.

     这个prototype的属性值是一个对象,默认的只有一个叫constructor的属性,指向这个函数本身。

   原型方式

     该方式利用了对象的 prototype 属性,可以把它看成创建新对象所依赖的原型。

     这里,首先用空构造函数来设置类名。然后所有的属性和方法都被直接赋予 prototype 属性。

     代码如下:

            function Car(){

     }

     Car.prototype.color = ‘blue‘;

     Car.prototype.doors = 4;

     Car.prototype.showColor = function(){

      alert(this.color)

     }

       var oCar1 = new Car();

       var oCar2 = new Car();

 

      

  hasOwnProperty()

    hasOwnProperty()函数用于指示一个对象自身(不包括原型链)是否具有指定名称的属性。如果有,返回true,否则返回false。

    语法:object.hasOwnProperty( propertyName )

    hasOwnProperty()函数的返回值为Boolean类型。如果对象object具有名称为propertyName的属性,则返回true,否则返回false。

    此方法不会检查对象的原型链中是否存在该属性,该属性只有是对象本身的一个成员才会返回true。

 

  原型链

    当从一个对象那里调取属性或者方法时,如果该对象自身不存在这样的属性或方法,就会去自己关联的prototype对象那里寻找,如果prototype没有,就会去prototype关联的前辈prototype那里寻找,如果在没有就继续寻找.....知道prototype为undefined(Object的prototype就是undfined)从而形成了所谓的“原型链”。

  具体关系请看下图:

    技术分享

 

    原型和原型链就到这里,希望对大家有帮助!

 

原型、原型链