JS中继承方案:罗列常见的四种

本文深入解析JavaScript中的四种主要继承方式:原型继承、call继承、寄生组合继承及ES6的class类继承。从原理到实践,全面理解JS面向对象机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1原型继承:子类的原型指向父类的一个实例

//父类
function Person() {
            this.name = "周乃康";
        }
        Person.prototype.getName = function getName() {
            console.log(this.name);
        };
         //子类
        function Boy() {
            this.bname = '周星星';
        }
        Boy.prototype.getbName = function getbName() {
            console.log(this.y);
        };
        //Boy子类 => Person父类,让子类Boy的原型指向父类Person的实例
        Boy.prototype = new Person; 
        let boy = new Boy;
        console.dir(Boy);

在这里插入图片描述
通过B.prototype = new A这一句话达成继承。
js中的面向对象的机制都是基于原型链完成的,所以js中的继承也可以是基于原型链的,但这其中又有很多弊端。

2 call继承

  //父类
    function Person() {
        this.name = "周乃康";
    }
    Person.prototype.getName = function getName() {
        console.log(this.name);
    };
    //子类
    function Boy() {
        Person.call(this);// ◆◆◆◆◆
        this.bname = "周星星";
    }
    Boy.prototype.getbName = function getbName() {
        console.log(this.bname);
    };
    let boy = new Boy;
    console.log(boy);
    boy.getbName();//打印周星星

在这里插入图片描述
call继承只能继承父类中的私有属性(继承的私有属性赋值给子类实例的私有属性),而且是类似拷贝过来一份,不是链式查找;因为只是把父类当做普通的方法执行,所以父类原型上的公有属性方法无法被继承过来。

3寄生组合继承:call继承 + 变异版的原型继承共同完成

//父类
        function Person() {
            this.name = "周定发";
        }
        Person.prototype.getName = function getName() {
            console.log(this.name);
        };
        //子类
        function Boy() {
            Person.call(this);
            this.bname = "周星星";
        }
        //=>Object.create(OBJ) 创建一个空对象,让其__proto__指向OBJ(把OBJ作为空对象的原型)
        Boy.prototype = Object.create(Person.prototype);
        Boy.prototype.constructor = Boy; //把constructor补上
        Boy.prototype.getbName = function getbName() {
            console.log(this.bname);
        };
        let boy = new Boy;
        console.log(boy);

在这里插入图片描述
利用了call继承实现私有到私有,利用原型继承实现了公有到公有。

4 ES6中的class类继承(语法糖)

class Person {
            constructor() {
                this.name = "周定发";
            }
            getName() {
                console.log(this.name);
            }
        }
        //=>extends继承和寄生组合继承基本类似
        class Boy extends Person {
            constructor() {
        //=>一但使用extends实现继承,只要自己写了constructor,就必须写super
                super();
                this.bname = "周星星";
            }
            getbName() {
                console.log(this.bname);
            }
        }

        let boy = new Boy;
        console.log(boy);

在这里插入图片描述
其实extends继承和寄生组合继承基本类似,而且必须加上super()函数,它相当于A.call(this)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值