JavaScript的寄生组合式继承

寄生组合式继承示例

第一篇博客,留个纪念

//父类构造函数
function Super(name){
    this.name = name;
    this.funcName = "Super";
    this.func = "super";
}
Super.prototype.sayName = function (){ alert(this.name); }
Super.prototype.sayFuncName = function (){ alert(this.funcName); }

//子类构造函数
function Sub(name,age){
    Super.call(this,name);
    this.age = age;
    this.funcName = "Sub";
}

//继承函数
function inheritPrototype(Sub,Super){
    //中间实例化对象
    var a = Object(Super.prototype);
    //重写该对象的构造函数指针,指向Sub函数
    a.constructor = Sub;
    //Sub的原型指向实例化对象a
    Sub.prototype = a;
}
//调用继承函数,实现原型链构造
inheritPrototype(Sub,Super);

/*
----------一定要在调用继承函数之后添加,如果放在继承函数之前,随着原型的替换,函数会undefined。----------
*/
//添加子类方法
Sub.prototype.sayAge = function (){ alert(this.age); }
Sub.prototype.sayFuncName = function (){ alert(this.funcName); }

//测试代码
var subTest = new Sub("lulu",20);
subTest.sayName(); //lulu
subTest.sayAge(); //20
subTest.sayFuncName(); //Sub
alert(subTest.func); //super







  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值