ES6继承

class关键字

<script>
        /* 
        1.class关键字: 声明类函数 (相当于构造函数)
            * (1)构造函数和原型对象写在一个大括号中: 代码清晰
            * (2)class类函数必须使用new关键字,不用则会报错 : 代码清晰
        class 函数名{
            //构造函数
            constructor(){

            }
            //原型对象的方法
            eat(){}
        }
        
        */
        
        //ES5原型语法

        //1.构造函数
        // function Person(name,age){
        //     this.name = name
        //     this.age = age
        // }

        //2.原型对象
        // Person.prototype.eat = function(){
        //     console.log('吃东西')
        // }

        //3.实例对象
        // let p1 = new Person('ikun',30)
        // console.log( p1 )


        //ES6类函数
        class Person{
            //1.构造函数
            constructor(name,age){
                this.name = name
                this.age = age
            }

            //2.原型方法
            eat(){
                console.log('吃东西')
            }
        }

        //3.实例对象
        let p1 = new Person('ikun',30)
        console.log( p1 )
        
        
    </script>

extends关键字

   <script>
/* extends关键字作用: 类继承 
        语法: class 子类函数 extends 父类函数
        底层: 替换原型继承(不会覆盖子构造函数的原型)
            我们课堂讲的替换原型:  s1.__proto__ = Person.prototype (会覆盖s1原来的原型)
            extends关键字替换原型的原型:
                s1.__proto__.__proto__ === Person.prototype (不会覆盖s1原来的原型)
        */
       class Student extends Person{
            //子构造函数原型方法
            learn(){
                console.log('我今天写的很开心')
            }
       }

       let s1 = new Student('刘',20)
       console.log(s1)
       s1.learn()//调用子类自己的方法
       s1.eat()//调用父类方法 (继承:拥有父类所有的成员)
       
        
        
    </script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值