javascript --- 原型继承与属性拷贝的综合应用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript --- 原型继承与属性拷贝的综合应用相关的知识,希望对你有一定的参考价值。

对于继承来说,主要目标就是将一些现有的功能据为己有。也就是说,我们在新建一个对象的时候,通常首先继承现有对象,然后再为其添加额外的属性和方法。

对此,我们可以通过一个函数调用来完成。

具体而言就是:

  1. 使用原型继承的方式,将一个已有对象设置成新对象的原型。

  2. 新建一个对象后,将另一个已有对象的属性拷贝过来。

function objectPlus(o, stuff){
    var n;
    function F(){};
    F.prototype = o.prototype;
    n = new F();
    n.uber = o;

    for(var i in stuff){
        n[i] = stuff[i];
    }
    return n;
}

这个函数接收两个参数o, stuff; 对象o用于继承,对象stuff用来拷贝方法和属性。我们来看一下实际应用:

首先,需要一个基本对象shape:

var pepole = {
    name: ‘Anna‘,
    toString: function(){
        return this.name;
    }
}

 

接着,创建一个继承于shape的对象,并为其添加额外的属性与方法。这些属性与方法与一个文本标识法创建的匿名对象提供:

var her = objectPlus(pepole,{
    name: ‘Jock‘,
    toString:function(){
        return this.usber.toString() + ‘,‘ +this.name;
    }
})

接下来,我们继续来创建一个继承her对象的his对象,也为其添加一些属性和方法:

var his = ObjectPlus(her, {
    name: ‘lus‘,
    getArea: function(){
        return this.side * this.height / 2;
    },
    side: 0,
    height: 0 
})

下面我们来测试一下:

var my = objectPublic(her, {
   side:4,
   height:4
})
my.getArea(); // 8
my.toString(); // Anna, Jock, Lus, Lus

这里的不同之处在于,执行toString()函数时,his的name属性会被执行两次,这是因为我们在实例化my的时候继承与her的,her自己又有name属性,所以这里又多了一层继承关系。

我们也可以给该实例一个新的name属性:

objectPuls(her, {
    side: 4,
    height: 4,
    name: ‘jiao‘
}).toString();
// Anna, Jock, Lus, jiao

 

对不住了,这两天有点懒,玩了个游戏,怀怀旧,来个A哥镇楼:╮(╯▽╰)╭╮(╯▽╰)╭╮(╯▽╰)╭

技术分享

 

以上是关于javascript --- 原型继承与属性拷贝的综合应用的主要内容,如果未能解决你的问题,请参考以下文章

javascript的继承方式总结

JavaScript原型与继承

JavaScript之基础-16 JavaScript 原型与继承

关于JavaScript的原型继承与原型链

JavaScript继承的几种方法

JavaScript的原型与继承