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 工具类型实战指南

相关推荐
kyriewen9 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒9 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马9 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮9 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦10 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer10 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队10 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY10 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_10 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏11 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端