使用 `DeepRequired` 后的所有属性都变成了必选属性,即使它们原来在原接口中是可选的.多用于对后端返回值的锁定必需

export type Primitive = undefined | null | boolean | string | number | symbol; export type DeepRequired<T> = T extends Primitive ? T : keyof T extends never ? T : { [K in keyof T]-?: DeepRequired<T[K]> };

在 TypeScript 中,DeepRequired<T> 是一个深度可选属性转为必选属性的类型。其作用是对传入的泛型 T 进行处理,如果 T 是原始类型(Primitive),则直接返回 T 本身;如果 T 不是原始类型,并且它没有索引签名(即 keyof T extends never),也直接返回 T;否则,对 T 的每个属性进行递归操作,将所有层级的可选属性转换为必选属性。

export type Primitive = undefined | null | boolean | string | number | symbol; // DeepRequired 类型定义 export type DeepRequired<T> = // 如果 T 是原始类型,则保持不变 T extends Primitive ? T : // 如果 T 没有索引签名(非对象或数组类型),也保持不变 keyof T extends never ? T : // 否则,对于 T 中的每个属性 K,将其变为必选属性,并递归应用 DeepRequired 到属性值上 { [K in keyof T]-?: DeepRequired<T[K]> };

例如,对于以下接口:

interface User { name?: string; age?: number; address?: { street?: string; city?: string; }; }

使用 DeepRequired<User> 将会得到:

{ name: string; age: number; address: { street: string; city: string; }; }

这意味着使用了 DeepRequired 后的所有属性都变成了必选属性,即使它们原来在原接口中是可选的。


__EOF__

本文作者龙陌
本文链接https://www.cnblogs.com/longmo666/p/18069683.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   龙陌  阅读(35)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示