编辑
2024-06-24
TS基础
00
请注意,本文编写于 207 天前,最后修改于 207 天前,其中某些信息可能已经过时。

目录

Omit
Pick
总结

最近面试中被问到了TypeScript中的Omit和Pick。第一时间就是尬住了,因为在工作里很少使用了TS,基本都是在写类型。这俩关键词,有点不面熟。面试结束后也是了解了一下,挺简单的两个类型工具。

TypeScript 中,OmitPick 是两个常用的类型工具,用于从现有类型中创建新类型,以便更精确地描述我们需要的数据结构。

Omit

Omit 类型工具允许我们从一个类型中剔除指定的属性,生成一个新的类型。其语法如下

ts
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;

这里的参数解释:

  • T:原始类型,从这个类型中我们要剔除属性。
  • K:属性名或属性名组成的联合类型,表示要从 T 中移除的属性。

举个例子,假设有一个 Person 类型:

ts
type Person = { name: string; age: number; address: string; };

如果我们想创建一个不包含 address 属性的新类型 PersonWithoutAddress,可以使用 Omit

ts
type PersonWithoutAddress = Omit<Person, 'address'>;

这样 PersonWithoutAddress 类型就只包含 nameage 两个属性了。

等价于:

ts
type PersonWithoutAddress = { name: string; age: number; };

Pick

Pick 类型工具与 Omit 正好相反,它允许我们从一个类型中选取指定的属性,生成一个新的类型。其语法如下:

ts
type Pick<T, K extends keyof T> = { [P in K]: T[P]; };

这里的参数解释:

  • T:原始类型,从这个类型中我们要挑选属性。
  • K:属性名或属性名组成的联合类型,表示要从 T 中选取的属性。

继续以上面的 Person 类型为例,如果我们想创建一个只包含 nameage 属性的新类型 PersonNameAndAge,可以使用 Pick

ts
type PersonNameAndAge = Pick<Person, 'name' | 'age'>;

这样 PersonNameAndAge 类型就只包含 nameage 两个属性了。

等价于:

ts
type PersonNameAndAge = { name: string; age: number; }

总结

  • Omit 用于从一个类型中剔除指定属性,生成一个新类型。
  • Pick 用于从一个类型中选择指定属性,生成一个新类型。

这两个类型工具在 TypeScript 中非常有用,可以帮助我们更精确地定义和操作类型,使得代码更具表现力和安全性,也能达到一定的复用性。

如果对你有用的话,可以打赏哦
打赏
ali pay
wechat pay

本文作者:CreatorRay

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!