JavaScript-寄生组合式继承

Posted 好多坨屎

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript-寄生组合式继承相关的知识,希望对你有一定的参考价值。

所谓寄生组合式继承,即通过构造函数来继承属性,通过原型式继承来继承方法,代码如下:

function inheritPrototype(sub,sup){
        var prototype = Object.create(sup.prototype);
        prototype.constructor = sub;
        sub.prototype = prototype;
    }

第一步是创建超类型原型的一个副本,第二步是弥补因重写原型而失去的默认的constructor属性,第三步是将副本复制给子类型的原型。

来试试如何调用吧,例如:

function Super(name){
        this.name = name;
        this.colors = ["red","blue","yellow"];
    }
    Super.prototype.sayName = function(){
        console.log(this.name);
    }
    function Sub(name){
        Super.call(this,name);
    }
    inheritPrototype(Sub,Super);

说白了,寄生组合式继承就是借用构造函数继承+原型式继承,只不过原型式继承里的object方法传的并不是对象本身,而是对象的原型。

以上是关于JavaScript-寄生组合式继承的主要内容,如果未能解决你的问题,请参考以下文章

Javascript继承6:终极继承者----寄生组合式继承

JavaScript之原型式继承&寄生式继承和寄生组合式继承以及优缺点

JavaScript-------寄生组合式继承

[javascript高手之路]寄生组合式继承的优势

javaScript设计模式之面向对象编程(object-oriented programming,OOP)--寄生组合式继承

Javascript 组合继承 原型链继承 寄生继承