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

相关推荐
naildingding25 分钟前
3-ts接口 Interface
前端·typescript
mONESY26 分钟前
JavaScript 栈、队列、数组与链表核心知识点总结
javascript·面试
小小前端仔LC32 分钟前
Node.js + LangChain + React:搭建个人知识库(六)- “吃什么”项目实战:从700+菜谱入库到Taro H5端JSON渲染
前端·后端
ZengLiangYi33 分钟前
TypeScript 项目配置:tsconfig、ESM、路径别名
javascript·typescript·aigc
晓13131 小时前
【Cocos Creator 3.x】篇——第二章 入门
前端·javascript·游戏引擎
想要成为糕糕手1 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
程序员黑豆1 小时前
AI全栈开发之Java:怎么配置Java环境变量
前端·后端·ai编程
xiaofeichaichai1 小时前
React Hooks
前端·javascript·react.js
数据知道1 小时前
C++ 层拦截:修改 Blink 引擎与 V8 绑定的底层逻辑
javascript·数据采集·指纹浏览器·风控
问心无愧05132 小时前
ctf show web入门110
前端·笔记