JS对象中的原型

对象的原型:每个对象都连接一个原型对象,并且它可以从中继承属性。所有通过对象字面量创建的对象都连接到object.prototype。当你创建一个新对象时,你可以选择某个对象作为它的原型。原型连接在更新时不起作用。当我们对某个对象作出改变时,不会触及该对象的原型。原型连接只有在检索值的时候才被用到。如果我们尝试去获取对象的某个属性值,但该对象没有此属性名,那么JS会试着从原型对象中获取属性值,如果那个原型对象也没有该属性,那么再从它的原型中找,以此类推,直到该过程最后到达终点Object.prototype。如果想要的属性完全不存在于原型链中,那么结果就是undefined值。这个过程成为“委托”。原型关系是一种动态的关系。如果我们添加一个新的属性到原型中,该属性会立即对所有基于该原型创建的对象可见。

//我们可以给object增加一个create方法。这个方法创建一个使用原对象作为其原型的新对象
if (typeof Object.beget !== 'function'){
    Object.create = function (o){
        var F = function (){};
        F.prototype = o;
        return new F()
    }
}
var stooge = {
    name: 'csh',
    age: 102
}
//新建一个对象,这个对象的原型是stooge对象
var another = Object.create(stooge);
another.name = 'abc'
console.log(another.name); //输出abc
delete another.name;
console.log(another.name); //输出csh
posted @ 2014-06-02 22:45  HX_追风  阅读(292)  评论(0编辑  收藏  举报