typescript - 当在一种情况下需要可选属性但在另一种情况下不需要时,如何优化接口对象的使用?
问题描述
我有以下界面:
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 的任何组合或什么都不传递。
最简单的方法是实现两个接口,一个具有必需属性,另一个没有它。但我觉得有更好的方法可以做到这一点,不要重复自己。
如何以最好的方式实现我的要求?
解决方案
如果您只需要将所有字段标记为可选,则可以使用这样的内置Partial<T>
类型:
type IPartialUserInfo = Partial<IUserInfo>;
// now type IUserInfo = {
// name?: string | undefined;
// surname?: string | undefined;
// dateOfBirth?: Date | undefined;
// }
你可以在这里试试。
推荐阅读
- xml - 寻找黑板测验文件的文件格式
- command-line - 让 drush 和 composer 在 Visual Studio Code 终端中工作
- excel - Excel::Writer::XLSX 写入无格式日期
- java - 使用 $in Mongodb - Java 进行不区分大小写的搜索
- hp-uft - UFT OTA - 获取复制的测试集文件夹的 ID
- java - 如何为 try & catch 实现指数延迟/睡眠
- css - 如何独立于其他列或行关注一列
- python - 来自 setup.py 的 dh_python2 版本化依赖项
- javascript - 从firebase数据库获取数据不起作用
- node.js - 使用 KMS、Node 从 S3 解密 SES 消息