微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JavaScript Es5继承以及Es6继承

Es5之前常用的三种继承

Es5继承 

原型链继承

//原型链继承
    //把父类的实力属性赋值给子类原型 , 就叫做原型链继承

    //父类
    function Fu(name) {
        this.name = name
        this.sleep = function () {
            console.log(this.name + "会飞");
        }
    }

    Fu.prototype.eat = function () {
        console.log(this.name + "会跑");
    }
    //子类

    function Zi() {
    }
    //子类继承父类
    Zi.prototype = new Fu('小明')
    let one = new Zi
    one.sleep()
    one.eat()
    console.log(one.name);

 构造函数继承

 //父类
    function Fu(name) {
        this.name = name
        this.sleep = function () {
            console.log(this.name + "会飞");
        }
    }
    Fu.prototype.eat = function(){
        console.log(this.name+"会跑"); //
    }
    //子类
    function Zi(name){
        Fu.call(this,name)
    }
    let one = new Zi('构造函数继承')
    console.log(one.name);
    one.sleep()
    //one.eat() // 报错  es5继承.html:102 Uncaught TypeError: one.eat is not a functionat 
                                                                                         
               

组合式继承

 // 组合式继承
    //原型链继承和构造函数继承的结合

    //优点 : 可以传参 可以继承原型上的实例属性

    // 父类
    function Fu(name) {
        this.name = name
        this.sleep = function () {
            console.log(this.name + "会飞");
        }
    }
    Fu.prototype.eat = function () {
        console.log(this.name + "会跑"); //
    }

    //子类
    function Zi(name){
        Fu.call(this,name)
    }

    Zi.prototype=new Fu()

    //修改constructor指针

    Zi.prototype.constructor=Zi

    let one = new Zi('组合式继承')

    console.log(one.name);

    one.eat()

    one.sleep()

Es6继承

class类 


    //es6的 class类  语法糖

    class Fu {
        constructor(name = "王", age = "18") {
            this.name = name
            this.age = age
        }
        eat() {
            console.log(`${this.name} ${this.age} eat food`);
        }
    }

    //继承父类
    class Zi extends Fu {
        constructor(name = "人", age = "20") {
            //继承父类属性
            super(name, age) //super指的是父亲的超集 people.call(this)
        }
        eat(){
            //继承父类方法
            super.eat()
        }
    }
    let ZiObj = new Zi('嘻嘻嘻')
    ZiObj.eat()
    console.log(ZiObj.name);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐