欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 产业 > TypeScript中的Omit和Pick

TypeScript中的Omit和Pick

2024/10/23 23:20:54 来源:https://blog.csdn.net/m0_46171043/article/details/140048963  浏览:    关键词:TypeScript中的Omit和Pick

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

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

Omit

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

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

这里的参数解释:

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

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

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

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

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

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

等价于:

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

Pick

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

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

这里的参数解释:

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

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

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

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

等价于:


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

总结

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com