秒懂 TypeScript 泛型工具类型!

开发 前端
而对于 Pick 工具类型来说,type 关键字用于给类型取个别名,方便重复使用,Pick 就是类型的名称。

如果你刚接触 TypeScript 不久,在阅读 TypeScript 内置工具类型的用法和内部实现的文章时,可能会看到 Pick 工具类型,对于该类型的语法你可能会感到陌生。

type Pick<T, K extends keyof T> = {
[P in K]: T[P];
};
type User = {
id: number;
name: string;
address: string;
};
type PickedUser = Pick<User, "id" | "name">;

其实学习新事物一种比较好的方式是使用类比。接下来阿宝哥将借助 JavaScript 中的函数来帮助你快速理解 Pick 工具类型背后的语法。

function Pick(obj, keys) {
const ret = {};
for (const key of keys) {
ret[key] = obj[key];
}
return ret;
}
const user = {
id: 666,
name: "阿宝哥",
address: "厦门",
};
const PickedUser = MyPick(user, ["id", "name"]);

在以上代码中,function 是关键字用于声明函数,Pick 是函数名称,而小括号内的 obj 和 keys 是参数,大括号中定义的是函数体。

图片

而对于 Pick 工具类型来说,type 关键字用于给类型取个别名,方便重复使用,Pick 就是类型的名称。尖括号内的 T 和 K 属于类型参数,与 JavaScript 函数中参数的区别是类型参数存储的是类型,而 JavaScript 函数参数存储的是值。

图片

其中 extends 是泛型约束的语法,用于约束类型的范围。 大括号中是该工具类型的具体实现,它使用了 TypeScript 映射类型的语法。

其实,你可以把 TypeScript 内置的工具类型理解成特殊的函数,它们被用于处理 TypeScript 中存在的类型。调用工具类型的方式与调用 JavaScript 函数的区别是使用的是尖括号。

最后,为了便于大家理解,阿宝哥以图片的形式来演示一下 Pick 工具类型的执行过程。

图片

图片

图片

如果你想详细了解映射类型,可以观看 “​​用了 TS 映射类型,同事直呼内行!”​​ 这篇文章。

责任编辑:姜华 来源: 全栈修仙之路
相关推荐

2024-11-05 09:11:09

TypeScript开发者代码

2023-05-12 09:08:48

TypeScript工具类型

2021-06-17 06:51:32

Java泛型Java编程

2023-01-05 17:13:28

TypeScript泛型组件

2021-10-17 13:10:56

函数TypeScript泛型

2011-04-13 09:16:55

泛型

2022-06-14 09:01:06

TypeScript泛型

2024-04-23 08:23:36

TypeScript泛型Generics

2023-11-20 13:51:00

泛型函数TypeScript

2009-09-08 16:36:10

LINQ查询基于泛型类

2009-08-24 14:51:25

C# 泛型泛型类型

2009-04-24 09:33:12

LINQ查询非泛型

2024-05-29 12:53:30

2013-03-20 09:27:33

C#泛型

2019-12-09 10:02:41

泛型ypeScript前端

2022-02-22 08:25:51

typeScript泛型概念泛型使用

2018-02-07 08:32:42

2009-09-14 18:57:19

LINQ查询

2020-04-20 10:33:56

戴尔

2018-04-26 08:40:33

线性回归算法机器学习
点赞
收藏

51CTO技术栈公众号