【前端Js】原型继承的几种方式

原型继承
父级:
 function Parent(name){
        this.name=name;
    }
    Parent.prototype.sayHello=function(){
        console.log("Hello,"+this.name);
    }
  
原型链继承
function Kid(){};
Kid.prototype=new Parent("who");

var k=new Kid();
console.log(k.name); //who
console.log(k.sayHello()); //Hello,who
弊端:创建实例时无法向父级传参

构造继承
function Kid(name){
    Parent.call(this,name);
};

var k=new Kid("who");
console.log(k.name); //who
console.log(k.sayHello()); //error
弊端:无法获取父级原型链属性


实例继承
function Kid(name){
    var p=new Parent(name);
    return p;
};

var k=new Kid("who");
console.log(k.name); //who
console.log(k.sayHello()); //Hello,who
弊端:实例是父级的实例


拷贝继承
function Kid(name){
    var p=new Parent(name);
    for(var item in p){
        Kid.prototype[item]=p[item];
    }
}
var k=new Kid("who");
console.log(k.name); //who
console.log(k.sayHello()); //Hello,who
弊端:太占用内存

组合继承
function Kid(name){
    Parent.call(this,name);
}
Kid.prototype=new Parent();
var k=new Kid("who");
console.log(k.name); //who
console.log(k.sayHello()); //Hello,who
弊端:调用了两次父类构造函数

寄生组合继承
function Kid(name){
    Parent.call(this,name);
}
(function(){
    var p=function(){};
    p.prototype=Parent.prototype;
    Kid.prototype=new p();
})()
弊端:写法比较繁琐
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值