您现在的位置是:首页 >技术交流 >TypeScript extends和implements区别网站首页技术交流

TypeScript extends和implements区别

多比熊 2024-06-14 17:20:13
简介TypeScript extends和implements区别
(被人理解是幸运的,但不被理解未必不幸。一个把自己的价值完全寄托于他人的理解上面的人往往并无价值。——周国平)

在这里插入图片描述

extends

相关文章

implements

implements是一个类实现一个接口用的关键字.实现一个接口,必须实现接口中的所有方法。

比如以下代码,定以了抽象类AbstractAnimal,然后Dog和Cat分别实现AbstractAnimal,Mouse继承AbstractAnimal,Pig继承AbstractAnimal并实现Dog, Cat。

abstract class AbstractAnimal {
  nickname = '动物';
  getData () {
    console.log('AbstractAnimal');
  };

  static staticNickname = '静态动物';
  static staticGetData () {
    console.log('staticGetData');
  }
}


class Dog implements AbstractAnimal {
  nickname: string;
  getData () {
    console.log('dog');
  }
}

class Cat implements AbstractAnimal {
  nickname: string;
  getData () {
    console.log('cat');
  }
  getSelfData () {
    console.log('get cat data');
  }
}

class Mouse extends AbstractAnimal { }

class Pig extends AbstractAnimal implements Dog, Cat {
  getSelfData (): void {
    throw new Error("Method not implemented.");
  }
}

我们也可以定义interface接口来进行多实现

interface IAnimal {
  nickname: string;
  getData ();
}


class Dog implements IAnimal {
  nickname: string;
  getData () {
    console.log('dog');
  }
}

class Cat implements IAnimal {
  nickname: string;
  getData () {
    console.log('cat');
  }
}


extends和implements的区别

  1. extends是继承类,implements是实现接口
  2. 类只能继承一个,接口可以实现多个
  3. extends继承父类的时候可以重写父类的方法,也可以调用父类的非私有方法;implements实现接口,必须实现接口的所有方法。
  4. extends后面跟的是类,表示继承关系
  5. implements后面跟的是接口,表示实现接口(可以是多个)
  6. 继承这个可以理解为继承父类的方法,父类中的方法可以在子类中用到
  7. 实现接口就是在接口中定义了方法,这个方法要你自己去实现,接口可以看作一个标准,用来统一业务接口规范

interface和implements的区别

  1. 抽象类可以提供成员方法的实现细节,而接口中只能存在public abstract (隐式声明)方法
  2. 抽象类中的成员变量和方法可以编写实现代码,而接口中的只能声明变量和方法
  3. 接口中不能含有静态代码块以及静态方法,而抽象类可以有静态代码块和静态方法
  4. 一个类只能继承一个抽象类,而一个类却可以实现多个接口
风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。