为了方便 TypeScript 用户,TypeScript 开发团队为我们提供了许多有用的内置实用程序类型。通过这些实用类型,我们
data:image/s3,"s3://crabby-images/c3a1c/c3a1c87b0d0db6754cbaa4e16281b5008459dd86" alt=""
可以轻松地转换类型、提取类型、排除类型,或者获取函数的参数类型或返回值类型。
在本文中,我从 TypeScript 的内置实用程序类型中挑选了 15 种非常有用的类型,并以图像的形式介绍了它们的用法和内部工作原理,看完这篇文章,相信你可以真正掌握这些内置实用程序类型的用法。
1.Partial<Type>
构造一个类型,其中 Type 的所有属性都设置为可选。
/** * Make all properties in T optional. * typescript/lib/lib.es5.d.ts */type Partial<T> = { [P in keyof T]?: T[P];};
2. Required<Type>
构造一个类型,该类型由设置为 required Type 的所有属性组成,部分的反义词。
data:image/s3,"s3://crabby-images/7f321/7f321bf1b27050850b790e5690009e2856987e6d" alt="图片 图片"
/** * Make all properties in T required. * typescript/lib/lib.es5.d.ts */type Required<T> = { [P in keyof T]-?: T[P];};
data:image/s3,"s3://crabby-images/e5f27/e5f2729ebc754b22ec54ab65038ae3d424d4ee8d" alt="图片 图片"
3.Readonly<Type>
构造一个 Type 的所有属性都设置为 readonly 的类型,这意味着构造类型的属性不能被重新分配。
data:image/s3,"s3://crabby-images/9fd44/9fd444c1939f261a3fe9cff407fcc44c46185d92" alt="图片 图片"
/** * Make all properties in T readonly. * typescript/lib/lib.es5.d.ts */type Readonly<T> = { readonly [P in keyof T]: T[P];};
4.Record<Keys, Type>
构造一个对象类型,其属性键为 Keys,其属性值为 Type,此实用程序可用于将一种类型的属性映射到另一种类型。
/** * Construct a type with a set of properties K of type T. * typescript/lib/lib.es5.d.ts */type Record<K extends keyof any, T> = { [P in K]: T;};
5. Exclude<UnionType, ExcludedMembers>
通过从 UnionType 中排除可分配给 ExcludedMembers 的所有联合成员来构造类型。
data:image/s3,"s3://crabby-images/628ef/628efe6073542c60c47655d42a2b18cb91b112d0" alt="图片 图片"
/** * Exclude from T those types that are assignable to U. * typescript/lib/lib.es5.d.ts */type Exclude<T, U> = T extends U ? never : T;
data:image/s3,"s3://crabby-images/01508/0150857e391199c0a9761e90f5f732d8512719a5" alt="图片 图片"
6. Extract<Type, Union>
通过从 Type 中提取所有可分配给 Union 的联合成员来构造一个类型。
/** * Extract from T those types that are assignable to U. * typescript/lib/lib.es5.d.ts */type Extract<T, U> = T extends U ? T : never;
7. Pick<Type, Keys>
通过从 Type 中选择一组属性 Keys(字符串文字或字符串文字的联合)来构造一个类型。
data:image/s3,"s3://crabby-images/2b2bc/2b2bc2834abc916cd7a3b3e18e5fd8ed3f9727e3" alt="图片 图片"
/** * From T, pick a set of properties whose keys are in the union K. * typescript/lib/lib.es5.d.ts */type Pick<T, K extends keyof T> = { [P in K]: T[P];};
data:image/s3,"s3://crabby-images/5bf0f/5bf0fcf999ab386ca5a24654bf16e00433d75fc7" alt="图片 图片"
8.Omit<Type, Keys>
通过从 Type 中选择所有属性然后删除 Keys(字符串文字或字符串文字的联合)来构造一个类型。
/** * Construct a type with the properties of T except for those * in type K. * typescript/lib/lib.es5.d.ts */type Omit<T, K extends keyof any> = Pick<T, Exclude<keyof T, K>>;
9. NonNullable<Type>
通过从 Type 中排除 null 和 undefined 来构造一个类型。
/** * Exclude null and undefined from T. * typescript/lib/lib.es5.d.ts */type NonNullable<T> = T extends null | undefined ? never : T;
10. Parameters<Type>
从函数类型 Type 的参数中使用的类型构造元组类型。
data:image/s3,"s3://crabby-images/10d40/10d40887de299cd04da211f8bc08f7444a167973" alt="图片 图片"
/** * Obtain the parameters of a function type in a tuple. * typescript/lib/lib.es5.d.ts */type Parameters<T extends (...args: any) => any> = T extends (...args: infer P) => any ? P : never;
11. ReturnType<Type>
构造一个由函数 Type 的返回类型组成的类型。
/** * Obtain the return type of a function type. * typescript/lib/lib.es5.d.ts */type ReturnType<T extends (...args: any) => any> = T extends (...args: any) => infer R ? R : any;
12. Uppercase<StringType>
将字符串文字类型转换为大写。
data:image/s3,"s3://crabby-images/89ab7/89ab7a21596ec12654923ea3a9cf3821345fe125" alt="图片 图片"
13.小写<StringType>
将字符串文字类型转换为小写。
data:image/s3,"s3://crabby-images/00759/00759c7c7b083652fc717a59d5795ff00dc62909" alt="图片 图片"
14. 大写<StringType>
将字符串文字类型的第一个字符转换为大写。
data:image/s3,"s3://crabby-images/b496c/b496ce26a69e3ae23d180bd77b1f08ada0df3558" alt="图片 图片"
15. 取消大写<StringType>
将字符串文字类型的第一个字符转换为小写。
data:image/s3,"s3://crabby-images/6ddc4/6ddc456c819ab722824befec0aa1bb2310958777" alt="图片 图片"
除了上述这些实用程序类型之外,还有一些其他常用的 TypeScript 内置实用程序类型,具体如下:
- ConstructorParameters<Type>:根据构造函数类型的类型构造元组或数组类型。它产生一个包含所有参数类型的元组类型(如果 Type 不是函数,则类型 never )。
- InstanceType<Type>:构造一个由Type中构造函数的实例类型组成的类型。
- ThisParameterType<Type>:为函数类型提取此参数的类型,如果函数类型没有此参数,则为未知。
本文介绍的实用程序类型在内部使用了有关映射类型、条件类型和推断类型推断的知识。如果你对映射类型和条件类型不熟悉,后面我将继续分享一些这个方面的知识。