首页 > 解决方案 > 从扩展接口扩展联合类型

问题描述

如果我有这个接口定义:

interface ModalProps {
    onClose: (event: {}, reason: 'backdropClick' | 'escapeKeyDown'): void;
}

现在我想补充一个额外的原因:

interface CustomModalProps {
    onClose: (event: {}, reason: 'backdropClick' | 'escapeKeyDown' | 'cancelClick'): void;
}

有什么方法可以从 CustomModalProps 中引用 ModalProps onClose 原因,这样我就不必复制这些值了?

interface CustomModalProps extends ModalProps {
  onClose: (event: {}, reason: ??? &| 'cancelClick'): void
}

标签: typescripttypescript-generics

解决方案


我们类型。

type ModalReason = 'backdropClick' | 'escapeKeyDown';

type CustomModaReason = ModalReason | 'cancelClick';

interface ModalProps {
    onClose: (event: {}, reason: ModalReason): void;
}

interface CustomModalProps {
    onClose: (event: {}, reason: CustomModaReason): void;
}

推荐阅读