TypeScript 中 extends 关键字

基础概念与语法介绍

extends关键字主要用于类、接口和泛型中,分别实现继承扩展约束功能。在类中,它允许一个类继承另一个类的属性和方法;在接口定义中,他用于合并接口,形成一个包含所有指定接口成员的新接口;而在泛型中,extends用于限制类型变量必须符合某种类型结构,增加了泛型的灵活性和类型的安全性。

类的继承

类的继承是面向对象编程的基本特征之一,extends在此发挥了核心作用。通过继承、子类可以复用父类的属性和方法,同时可选择性的覆盖或扩展他们

typescript 复制代码
class Animal {
  name: string;

  constructor(name: string){
    this.name = name;
  }

  speak(){
    console.log(`${this.name} is Animal`)
  }
}

class Dog extends Animal {
  speak(){
    console.log(`${this.name} Dog`)
  }
}

在这个例子中,Dog类通过extends继承了Animal类,并覆盖了speak方法以提供更具体的实现。

接口的扩展

接口扩展是TypeScript中实现接口复用组合的强大机制。利用extends,可以创建一个接口,它包含一个或多个其他接口所有成员。

基本接口扩展

假设你有两个基本接口,一个描述了动物的一般特征,另一个专门描述了鸟类的特征。

typescript 复制代码
interface Animal {
    name: string;
    age: number;
}

interface Brid extends Animal {
    fly(): void;
    sing(): string;
}

let brid: Brid = {
    name: 'zyj',
    age: 1,
    fly() {
        console.log('fly');
    },
    sing() {
        return 'sing'
    }
}

在这里,Bird接口通过extends关键字扩展了Animal接口,这就意味着一个实现了Brid接口的对象除了需要有flysing方法还必须有nameage属性。

多接口扩展

有时候一个类或接口可能需要符合多个接口的规范。TypeScript支持多重继承,即一个接口可以扩展多个其他接口。

typescript 复制代码
interface Swinmer {
    swim(): void;
}

interface Flyer {
    fly(): void;
}

interface Duck extends Swinmer, Flyer {
    quack(): void;
}

let duck: Duck = {
    swim() {
        console.log('swim')
    },
    fly() {
        console.log('fly')
    },
    quack() {
        console.log('quack')
    },
}

在上面的例子中,Duck接口通过扩展SwimmerFlyer接口,要求实现了Duck的类型还需要有swimfly方法,以及自己的quack方法。

泛型接口与扩展

接口扩展也可以与泛型一起使用,为泛型类型增加更多约束或行为。

typescript 复制代码
interface Loggable<T> {
    log(message: T): void;
}

interface Identifiable<T> {
    id: T;
}

interface User extends Identifiable<number>, Loggable<string> {
    name: string;
    email: string;
}

const user: User = {
    id: 1,
    name: 'zyj',
    email: '123@qq.com',
    log(message: string) {
        console.log(message)
    }
}

在这个例子中,User接口不仅有自己的属性nameemail,还通过扩展Identifiable<number>获得了id属性,并且通过扩展Loggable<string>要求有一个接受字符串参数的log方法。

我是菜逼,大佬勿喷!

相关推荐
还是大剑师兰特1 小时前
TypeScript 面试题及详细答案 100题 (91-100)-- 工程实践与框架集成
前端·javascript·typescript·1024程序员节
fruge12 小时前
TypeScript 基础类型与接口详解
javascript·ubuntu·typescript
海鸥两三1 天前
Uni-App(Vue3 + TypeScript)项目结构详解 ------ 以 Lighting-UniApp 为例,提供源代码
vue.js·typescript·uni-app·1024程序员节
菜鸟una2 天前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
前端初见2 天前
快速上手TypeScript,TS速通
javascript·ubuntu·typescript
郑板桥302 天前
TypeScript:npm的types、typings、@type的区别
javascript·typescript·npm
Java陈序员2 天前
免费高颜值!一款跨平台桌面端视频资源播放器!
vue.js·typescript·electron
菜鸟una3 天前
【瀑布流大全】分析原理及实现方式(微信小程序和网页都适用)
前端·css·vue.js·微信小程序·小程序·typescript
还是大剑师兰特3 天前
TypeScript 面试题及详细答案 100题 (71-80)-- 模块与命名空间
前端·javascript·typescript
一点七加一3 天前
Harmony鸿蒙开发0基础入门到精通Day01--JavaScript篇
开发语言·javascript·华为·typescript·ecmascript·harmonyos