typescript 类

最简单的实现一个类,并用上之前讲过的``

class person{
    name;
    eat() { 
        console.log(`${this.name}吃吃吃`)
    }
}
var mike = new person();
mike.name = "mike"
mike.eat()

var jason = new person()
jason.name = "jason"
jason.eat()

需要提示的是 如果name 前面加上private  实例调用name就会报错~ 例如mike.name就会报错,输出结果及报错

2.类的构造方法

class person{
    constructor(name:string) {
        this.name =name
    }
    name;
    eat() { 
        console.log(`${this.name}吃吃吃`)
    }
}
var mike = new person("mike");
mike.eat()

var jason = new person("jason")
jason.eat()

通过构造方法 对name属性进行赋值 ,可以继续简化成如下写法

class person{
    constructor(public name:string) {
        this.name =name
    }
    eat() { 
        console.log(`${this.name}吃吃吃`)
    }
}

注意此种写法,必须加上public 不然不会自动创建属性

3.extends 继承

class person{
    constructor(public name:string) {
        this.name =name
    }
    eat() { 
        console.log(`${this.name}吃吃吃`)
    }
}

class employee extends person {

}

var e1 = new employee("didi")
e1.eat()

继承可以继承 属性和方法 结果如下

4.super的用法

class person{
    constructor(public name:string) {
        this.name =name
    }
    eat() { 
        console.log(`${this.name}吃吃吃`)
    }
}

class employee extends person {
    constructor(name: string, code: string) { 
        super(name)
        this.code = code
    }
    code: string
    Worker() { 
        super.eat()
        this.towork()
    }
    private towork() {
        console.log("去工作")
    }
}

var e1 = new employee("didi","001")
e1.Worker()

可以看到两种用法,

1.子类的构造函数,必须调用父类的super方法,否则会爆红。

2.子类方法中 可以调用父类的方法。例如super.eat()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值