TypeScript 中 omit 和 record 用法

在 TypeScript 中,OmitRecord 是两个内置的高级工具类型,它们可以组合使用,以实现更灵活的类型操作。


基本概念

  • 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

✅ 示例

ts 复制代码
// 定义一个 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 中,过滤掉不需要的属性以减少状态体积。
  • 表单处理:提交表单时排除某些字段(如 createdAtupdatedAt)。

补充说明

  • Omit 从 TypeScript 3.5+ 开始支持,需确保 tsconfig.jsontargetES2019
  • 若需选择保留某些字段而非移除,可考虑使用 Pick

如需进一步了解工具类型对比,可参考:TypeScript 工具类型实战指南

相关推荐
Lee川1 小时前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
canonical_entropy2 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香2 小时前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!2 小时前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ3 小时前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!4 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者4 小时前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端5 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式
霜落花轻扬5 小时前
在新选项卡中显示链接【html中 target=“_blank“】
前端·html