TypeScript 中 omit 和 record 用法小结
更新时间:2026年05月27日 09:34:56 作者:AI 前端
TypeScript中Omit和Record工具类型可以组合使用实现灵活的类型操作,Record创建键为K、值为T的对象类型,Omit从T中移除指定键,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
在 TypeScript 中,Omit 和 Record 是两个内置的高级工具类型,它们可以组合使用,以实现更灵活的类型操作。
基本概念
- Record<K, T>:创建一个对象类型,其键为类型 K,值为类型 T。
- 例如:Record<'a' | 'b', string> 表示一个对象,键只能是 'a' 或 'b',值必须是 string。
- Omit<T, K>:从类型 T 中移除指定的键 K,返回一个新类型。
- 例如:Omit<{name: string; age: number}, 'age'> 得到 {name: string}。
Omit Record 的典型用法
当你有一个基于 Record 定义的类型,并希望移除其中某些键时,就可以使用 Omit。
✅ 示例
// 定义一个 Record 类型:用户 ID 映射到用户信息
type UserMap = Record<string, { id: number; name: string; password: string }>;
// 移除 password 字段,用于 API 响应脱敏
type SafeUserMap = Record<string, Omit<UserMap[string], 'password'>>;
// 等价于:
// type SafeUserMap = Record<string, { id: number; name: string }>;
🔍 解释
- UserMap[string] 提取 Record 的值类型,即 { id: number; name: string; password: string }。
- Omit<UserMap[string], 'password'> 移除 password,得到 { id: number; name: string }。
- 外层再用 Record<string, ...> 包裹,保持键仍为 string 类型。
实际应用场景
- API 脱敏:从包含敏感字段(如密码、token)的 Record 类型中移除特定字段。
- 状态管理:在 Redux 或 Zustand 中,过滤掉不需要的属性以减少状态体积。
- 表单处理:提交表单时排除某些字段(如 createdAt、updatedAt)。
补充说明
- Omit 从 TypeScript 3.5+ 开始支持,需确保 tsconfig.json 中 target ≥ ES2019。
- 若需选择保留某些字段而非移除,可考虑使用 Pick。
如需进一步了解工具类型对比,可参考:TypeScript 工具类型实战指南。
到此这篇关于TypeScript 中 omit 和 record 用法的文章就介绍到这了,更多相关TypeScript omit record 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JavaScript鼠标事件,点击鼠标右键,弹出div的简单实例
下面小编就为大家带来一篇JavaScript鼠标事件,点击鼠标右键,弹出div的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-08-08
基于Bootstrap的UI扩展 StyleBootstrap
这篇文章主要为大家详细介绍了基于Bootstrap的UI扩展: StyleBootstrap,感兴趣的小伙伴们可以参考一下2016-06-06


最新评论