美文网首页
JavaScript组合继承

JavaScript组合继承

作者: oneways | 来源:发表于2019-07-21 19:13 被阅读0次

    组合继承(combination inheritance),有时候也叫做伪经典继承,指的是将原型链和借用构造函数的技术组合到一块,从而发挥二者之长的一种继承模式。其背后的思路是使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承。这样,既通过在原型上定义方法实现了函数复用,又能够保证每个实例都有它自己的属性。下面来看一个例子。

    //组合继承
    function SuperType(name){
        this.name = name;
        this.colors=["red","blue","green"];
    }
    SuperType.prototype.sayName = function(){
        console.log(this.name);
    };
    function SubType(name,age){
        //继承属性
        SuperType.call(this,name);
        this.age = age;
    }
    //继承方法
    SubType.prototype = new SuperType();
    SubType.prototype.constructor = SubType;
    SubType.prototype.sayAge = function(){
        console.log(this.age);
    }
    var instance1 = new SubType("Nicholas",29); 
    instance1.colors.push("black");
    console.log(instance1.colors);   //[ 'red', 'blue', 'green', 'black' ]
    instance1.sayName();    //Nicholas
    instance1.sayAge();     //29
    
    var instance2 = new SubType("Greg",27);
    console.log(instance2.colors);  //[ 'red', 'blue', 'green' ]
    instance2.sayName();    //Greg
    instance2.sayAge();     //27
    

    在这个例子中,SuperType构造函数定义了两个属性:name和colors。SuperType的原型定义了一个方法sayName()。SubType构造函数在调用SuperType构造函数时传入了name参数,紧接着又定义了它自己的属性age。然后,将SuperType的实例赋值给SubType的原型,然后又在该新原型上定义了方法sayAge()。这样一来,就可以让两个不同的SubType实例既分别拥有自己属性----包括colors属性,又可以使用相同的方法了。
    组合继承避免了原型链和借用构造函数的缺陷,融合了它们的优点,成为了JavaScript中最常用的继承模式。而且,instanceof 和isPrototypeOf()也能够用于识别基于组合继承创建的对象。

    相关文章

      网友评论

          本文标题:JavaScript组合继承

          本文链接:https://www.haomeiwen.com/subject/gmdvlctx.html