javascript中继承的3种方式

function S() {
    this.name = "sss";
}
S.prototype.say = function() {
    console.log(this.name);
}

//ES6
class A extends S {
    constructor(){
        super();
    }
}

//寄生组合继承
function B() {
    S.call(this);
}
B.prototype = Object.create(S.prototype)
B.prototype.constructor = B;

//组合继承(构造函数+原型),原型中会多父构造函数中的属性
function C() {
    S.call(this);
}
C.prototype = new S();
C.prototype.constructor = C;

var a = new A();
a.say();
console.log(a instanceof A);
console.log(a instanceof S);
console.log(A.prototype.isPrototypeOf(a));
console.log(S.prototype.isPrototypeOf(a));

var b = new B();
b.say();
console.log(b instanceof B);
console.log(b instanceof S);
console.log(B.prototype.isPrototypeOf(b));
console.log(S.prototype.isPrototypeOf(b));

var c = new C();
c.say();
console.log(c instanceof C);
console.log(c instanceof S);
console.log(C.prototype.isPrototypeOf(c));
console.log(S.prototype.isPrototypeOf(c));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值