8.0 TypeScript super关键字

上一篇:

6.0 站在生物学的角度看TypeScript类的继承_十一月丶萧邦的博客-CSDN博客

紧接上篇,本文记录TypeScript类的super关键字

首先看一段代码,这段代码是错误的,无法运行的!!!

    class Animal {
        name: string
        constructor(name: string) {
            this.name = name
        }
        say(): string {
            return '嗷呜嗷呜'
        }
    }
    class Dog extends Animal {
        age: number

        constructor(age: number) {
            this.age = age
        }
    }
    const dog = new Dog(18)
    console.log(dog)

如果你的编辑器是webstorm,应该就会直接给你报错,挂掉了!

控制台也会报错

 我们的本意其实就很简单,在子类Dog中添加了一个属性,使用了构造函数,然后就挂掉了,那么如何写才正确呢?那就是super关键字了!

    class Dog extends Animal {
        age: number

        constructor(name: string, age: number) {
            super(name)
            this.age = age
        }
    }

    const dog = new Dog('旺财', 3)
    console.log(dog)

记录:当子类继承了父类,我们在子类中使用了构造函数的时候,我们必须要使用super关键字将继承的父类属性拿过来才行

我觉得形象一点,在子类中使用构造函数,与父类中的构造函数并不会合并到一块,我们只能再写一遍父类的属性,通过super拿过来。

再阅读下一段代码:

    class Dog extends Animal {
        age: number
        constructor(name: string, age: number) {
            super(name)
            this.age = age
        }
        run(): void {
            console.log(`${this.name}在跑,一边跑一边${super.say()}`)
        }
    }
    const dog = new Dog('旺财', 3)
    console.log(dog);
    dog.run()

我们在子类Dog中添加了一个run的执行方法,通过super.say() 来访问到了继承的父类中的say方法,

说明在类的方法中,super表示当前类的父类,可以通过super关键字来访问父类的方法

页面:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Jay丶萧邦

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

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

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

打赏作者

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

抵扣说明:

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

余额充值