JavaScript继承

JavaScript的继承分为7种

1. 原型继承

2. 借用继承

3. 组合继承

4. 拷贝继承

5. 组合继承2

6. 寄生继承

7. 寄生式组合继承

下面是各个继承的详细解释

1. 原型继承

核心:让子类的原型指向父类的实例(子类.prototype = new 父类())

优点:能够继承父类的属性和方法

缺点:1. 子类不能有自己的私有方法,也就是没有自己的原型

           2. 继承下来的属性是一模一样的

原型继承代码实现 :

        此时子类的原型上就有父类的属性和方法

function Person(name,age){
    this.name = name;
    this.age = age
}
Person.prototype.sayHi = function () { console.log('Hi') }

function Student(gender){
    this.gender = gender;
}
Student.prototype = new Person('zs',18)

 2. 借用继承

核心:利用call调用父类构造函数,改变父类构造函数的this指向(父类.call(this))

优点:1. 子类能够有属于自己的独立的私有属性

           2. 有自己的原型

缺点:子类不能继承父类的方法

借用继承代码实现:

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {console.log('Hi')}

function Student(gender,name,age){
    Person.call(this,name,age)
    this.gender = gender;
}
Student.prototype.sayHello = function () {console.log('Hello')}

 

3. 组合继承

核心:原型继承 + 借用继承

优点:1. 能够继承父类的属性和方法

           2. 每个继承下来的属性都是自己独立的私有属性

缺点:1. 还是没有自己的原型

           2. 多余一套没有用的属性

组合继承的实现 :

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {consloe.log('Hi')}

function Student(gender,name,age){
    Person.call(this,name,age);
    this.gender = gender;
}
Student.prototype = new Person()

 4. 拷贝继承

核心:将父类的实例上面的东西遍历一遍到子类的原型上

优点:1. 可以继承到父类的属性和方法

           2. 有自己的原型,可以添加自己的私有方法

缺点:需要时间

拷贝继承的实现 :

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {console.log('Hi')}

function Student(gender){
    this.gender = gender;
}
const p = new Person('zs',18);
for(let k in p){
    Student.prototype[k] = p[k];
}

 

5. 组合继承2

核心:借用继承 + 拷贝继承的一部分

优点:1. 子类继承下来的属性是独立的私有属性

           2. 有自己的原型,可以添加属于自己的私有方法

           3. 能继承父类的属性和方法

缺点:和拷贝继承一样,需要时间 

组合继承2的代码实现 

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {console.log('Hi')}

function Student(gender,name,age){
    Person.call(this,name,age);
    this.gender = gender;
}
for(let k in Person.prototype){
    Student.prototype[k] = Person.prototype[k];
}

 6. 寄生继承

核心:利用中间构造函数实现对父类的寄生

优点:有属于自己的原型

缺点:1. 不能继承父类的属性

           2. 多一个中间构造函数的变量名

寄生继承的实现 

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {console.log('Hi')}

function Student(gender){
    this.gender = gender;
}

function Third(){}
Third.prototype = Person.prototype;
Student.prototype = new Third();

 7. 寄生式组合继承

核心: 借用继承 + 寄生继承

优点:1. 能够继承父类的属性和方法

           2. 继承下来的属性是自己的私有属性

           3. 有自己的原型,可以添加自己的私有方法

寄生式组合继承的实现 

function Person(name,age){
    this.name = name;
    this.age = age;
}
Person.prototype.sayHi = function () {console.log('Hi')}

function Student(gender,name,age){
    Person.call(this,name,age);
    this.gender = gender;
}

(function (){
    function Third();
    Third.prototype = Person.prototype;
    Student.prototype = new Third();
    Student.prototype.constructor = Student;
})()

 

ES6的继承语法:

class Person{...}

class Student extends Person{

        constructor(){

                super()

        }

}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蒸肉米粉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值