首页 > 解决方案 > 当在一种情况下需要可选属性但在另一种情况下不需要时,如何优化接口对象的使用?

问题描述

我有以下界面:

interface IUserInfo {
    name: string,
    surname: string,
    dateOfBirth: Date
}

在我的应用程序的某些地方,我需要确保开发人员提供了一个 IUserInfo 对象,该对象具有函数的所有属性:

const someFunc = (state: IUserInfo) => {
    // I want to get an error if developer tries to pass an object without name, surname or dateOfBirth
}

在其他情况下,我需要有可能传递相同类型的对象,但具有可选属性,因此用户应该能够传递姓名/姓氏/dateOfBirth 的任何组合或什么都不传递。

最简单的方法是实现两个接口,一个具有必需属性,另一个没有它。但我觉得有更好的方法可以做到这一点,不要重复自己。

如何以最好的方式实现我的要求?

标签: typescriptdesign-patternstypesinterfacedry

解决方案


如果您只需要将所有字段标记为可选,则可以使用这样的内置Partial<T>类型:

type IPartialUserInfo = Partial<IUserInfo>;
// now type IUserInfo = {
//    name?: string | undefined;
//    surname?: string | undefined;
//    dateOfBirth?: Date | undefined;
// }

你可以在这里试试。


推荐阅读