TypeScript 入门教程: 接口

ts接口相关
更新于: 2023-09-05 07:55:30

接口

在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型。

  • implement: 在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类(classes)去实现(implement)。
  • shape: TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。
// 任意属性
interface Person {
    name: string;
    age?: number;
    [key: string]: any;
}

// 只读属性
interface Person {
    readonly id: number;
    name: string;
    age?: number;
    [propName: string]: any;
}

函数的合并

function reverse(x: number): number;
function reverse(x: string): string;
function reverse(x: number | string): number | string {
    if (typeof x === 'number') {
        return Number(x.toString().split('').reverse().join(''));
    } else if (typeof x === 'string') {
        return x.split('').reverse().join('');
    }
}

接口合并

  • 不同的key 会直接 merge
  • 相同的key,如果类型一致就没事
  • 相同的key,如果类型不一致就会报错j
interface Alarm {
    price: number;
}
interface Alarm {
    weight: number;
}

// --- 类型一致,虽然重复,但不会报错
interface Alarm {
    price: number;
}
interface Alarm {
    price: number;  // 虽然重复了,但是类型都是 `number`,所以不会报错
    weight: number;
}

带函数的合并

interface Alarm {
    price: number;
    alert(s: string): string;
}
interface Alarm {
    weight: number;
    alert(s: string, n: number): string;
}

// ---- 相当于以下结果

interface Alarm {
    price: number;
    weight: number;
    alert(s: string): string;
    alert(s: string, n: number): string;
}

参考