码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript-寄生组合式继承

时间:2019-11-06 14:57:13      阅读:107      评论:0      收藏:0      [点我收藏+]

标签:rip   通过   obj   借用构造函数继承   console   原型   属性   pre   style   

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

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-寄生组合式继承

标签:rip   通过   obj   借用构造函数继承   console   原型   属性   pre   style   

原文地址:https://www.cnblogs.com/gehaoyu/p/11805084.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!