一个构造函数继承另一个构造函数的原型方法

方法1

function Person() {

}

function Hello() {

}

Person.prototype.name = "lily";
Hello.prototype = Person.prototype;

console.log(Person.prototype);
console.log(Hello.prototype);

 

这样的继承方式很简单,但是有一个问题,就是当Hello构造函数自身添加原型对象或者方法的时候,Person构造函数的原型也会被影响到。

function Person() {

}

function Hello() {

}

Person.prototype.name = "lily";
Hello.prototype = Person.prototype;

console.log(Person.prototype);
console.log(Hello.prototype);

Hello.prototype.sayName = function() {
    console.log(this.name);
}

一般我们都不想要这样的结果,所以这个方法并不可行。

 

方法2 -- 圣杯模式

我们想要实现的继承是在Hello构造函数里添加自身的原型方法时被继承的构造函数Person不被影响到,这里使用的方法是利用一个中间层函数,代码如下:

function Person() {

}

function Hello() {

}

Person.prototype.name = "lily";

let inherit = function(Target, Origin) {
    function F() {}
    F.prototype = Origin.prototype;
    Target.prototype = new F();
    Target.constuctor = Target;
    Target.prototype.uber = Origin.prototype;
}

inherit(Hello, Person);

Hello.prototype.sayName = function() {
    console.log(this.name);
}

console.log(Person.prototype);
console.log(Hello.prototype);

可以看到打印出来的结果,Hello构造函数里新添加的sayName方法并没有影响到Person构造函数。这是因为Hello和Person的原型指向并不是同一个地址了,只是Hello继承了Person的原型而已。

方法二的另一种写法:

let inherit = (function() {
    function F() {}
    return function(Target, Origin) {
        F.prototype = Origin.prototype;
        Target.prototype = new F();
        Target.constuctor = Target;
        Target.prototype.uber = Origin.prototype;
    }
}())

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值