typescript学习之旅----静态属性 静态方法 抽象类 多态

// 静态属性 静态方法
/*
    function Person(){
        this.run1=function(){
        }
    }
    Person.name='哈哈哈';
    Person.run2=function(){  静态方法
    }
    var p=new Person();
    Person.run2(); 静态方法的调用
*/

// class Per {
//   public name: string;
//   public age: number = 20;
//   //静态属性
//   static sex = "男";
//   constructor(name: string) {
//     this.name = name;
//   }
//   run() {  /*实例方法*/
//     alert(`${this.name}在运动`)
//   }
//   work() {
//     alert(`${this.name}在工作`)
//   }
//   static print() {  /*静态方法  里面没法直接调用类里面的属性*/
//     alert('print方法' + Per.sex);
//   }
// }
// // var p=new Per('张三');
// // p.run();
// Per.print();
// alert(Per.sex);

//多态:父类定义一个方法不去实现,让继承它的子类去实现  每一个子类有不同的表现 
//多态属于继承
// class Animal {
//   name: string;
//   constructor(name: string) {
//     this.name = name;
//   }
//   eat() {   //具体吃什么  不知道   ,  具体吃什么?继承它的子类去实现 ,每一个子类的表现不一样
//     console.log('吃的方法')
//   }
// }
// class Dog extends Animal {
//   constructor(name: string) {
//     super(name)
//   }
//   eat() {
//     return this.name + '吃粮食'
//   }
// }
// class Cat extends Animal {
//   constructor(name: string) {
//     super(name)
//   }
//   eat() {
//     return this.name + '吃老鼠'
//   }
// }
//typescript中的抽象类:它是提供其他类继承的基类,不能直接被实例化。
//用abstract关键字定义抽象类和抽象方法,抽象类中的抽象方法不包含具体实现并且必须在派生类中实现。
// abstract抽象方法只能放在抽象类里面
// 抽象类和抽象方法用来定义标准 。   标准:Animal 这个类要求它的子类必须包含eat方法
//标准:

abstract class Animal {
  public name: string;
  constructor(name: string) {
    this.name = name;
  }
  abstract eat(): any;  //抽象方法不包含具体实现并且必须在派生类中实现。
  run() {
    console.log('其他方法可以不实现')
  }
}
// var a=new Animal() /*错误的写法*/
class Dog extends Animal {
  //抽象类的子类必须实现抽象类里面的抽象方法
  constructor(name: any) {
    super(name)
  }
  eat() {
    console.log(this.name + '吃粮食')
  }
}
var d = new Dog('小花花');
d.eat();

class Cat extends Animal {
  //抽象类的子类必须实现抽象类里面的抽象方法
  constructor(name: any) {
    super(name)
  }
  run() {
    console.log(this.name)
  }
  eat() {
    console.log(this.name + '吃老鼠')
  }
}
var c = new Cat('小花猫');
c.eat();

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

瑞朋哥

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

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

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

打赏作者

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

抵扣说明:

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

余额充值