所有 TypeScript 中内置的泛型类型(Generic Utility Types)

所有 TypeScript 中内置的泛型类型(Generic Utility Types)


1. Awaited<Type>

说明:获取 Promise 类型中 resolve 的值类型。

ts 复制代码
type A = Awaited<Promise<number>>; // A: number

2. Partial<Type>

说明:将对象类型的所有属性变为可选。

ts 复制代码
interface User { name: string; age: number; }
type PartialUser = Partial<User>; // { name?: string; age?: number; }

3. Required<Type>

说明:将对象类型的所有属性变为必选。

ts 复制代码
interface User { name?: string; age?: number; }
type RequiredUser = Required<User>; // { name: string; age: number; }

4. Readonly<Type>

说明:将对象类型的所有属性变为只读。

ts 复制代码
interface User { name: string; }
type ReadonlyUser = Readonly<User>; // { readonly name: string; }

5. Record<Keys, Type>

说明:创建一个对象类型,key集合由 Keys 指定,值的类型是 Type。

ts 复制代码
type Scores = Record<'math' | 'english', number>; // { math: number; english: number; }

6. Pick<Type, Keys>

说明:从对象类型中选择一组属性,组成新的类型。

ts 复制代码
interface User { name: string; age: number; sex: string; }
type NameAndAge = Pick<User, 'name' | 'age'>; // { name: string; age: number; }

7. Omit<Type, Keys>

说明:从对象类型中去除一组属性,剩下一组属性组成新类型。

ts 复制代码
interface User { name: string; age: number; sex: string; }
type UserWithoutAge = Omit<User, 'age'>; // { name: string; sex: string; }

8. Exclude<UnionType, ExcludedMembers>

说明:从联合类型中排除一组类型,生成新的联合类型。

ts 复制代码
type T = Exclude<'a' | 'b' | 'c', 'a'>; // 'b' | 'c'

9. Extract<Type, Union>

说明:从联合类型中提取出所有可以赋值给 Union 的成员。

ts 复制代码
type T = Extract<'a' | 'b' | 'c', 'a' | 'f'>; // 'a'

10. NonNullable<Type>

说明:去除类型中的 null 和 undefined。

ts 复制代码
type T = NonNullable<string | number | undefined>; // string | number

11. Parameters<Type>

说明:获取函数参数类型组成的元组类型。

ts 复制代码
function foo(a: number, b: string): void {}
type T = Parameters<typeof foo>; // [number, string]

12. ConstructorParameters<Type>

说明:获取构造函数的参数类型组成的元组类型。

ts 复制代码
class Person { constructor(age: number, name: string) {} }
type T = ConstructorParameters<typeof Person>; // [number, string]

13. ReturnType<Type>

说明:获取函数返回值的类型。

ts 复制代码
function foo(): boolean { return true }
type T = ReturnType<typeof foo>; // boolean

14. InstanceType<Type>

说明:获取构造函数实例的类型。

ts 复制代码
class Person {}
type T = InstanceType<typeof Person>; // Person

15. NoInfer<Type>

说明:阻止类型参数被自动推断,常用于类型约束和高级类型体操中。

ts 复制代码
function foo<T, U = NoInfer<T>>(arg: T, value: U): [T, U] { return [arg, value]; }

16. ThisParameterType<Type>

说明:获取函数的 this 参数类型。

ts 复制代码
function fn(this: Date, x: number) {}
type T = ThisParameterType<typeof fn>; // Date

17. OmitThisParameter<Type>

说明:返回删除 this 参数后的函数新类型。

ts 复制代码
function fn(this: Date, x: number) { }
type T = OmitThisParameter<typeof fn>; // (x: number) => void

18. ThisType<Type>

说明:指定对象字面量中 this 的类型(只在对象字面量中有用)。

ts 复制代码
type Obj = { x: number } & ThisType<{ y: string }>;
// obj.y 的类型将被推断为 string

Intrinsic String Manipulation Types

字符串内置操作类型

a. Uppercase<StringType>

说明:将字符串类型全转为大写。

ts 复制代码
type Str = Uppercase<'abc'>; // "ABC"
b. Lowercase<StringType>

说明:将字符串类型全转为小写。

ts 复制代码
type Str = Lowercase<'ABC'>; // "abc"
c. Capitalize<StringType>

说明:将字符串类型首字母大写。

ts 复制代码
type Str = Capitalize<'hello'>; // "Hello"
d. Uncapitalize<StringType>

说明:将字符串类型首字母小写。

ts 复制代码
type Str = Uncapitalize<'Hello'>; // "hello"

相关推荐
2501_944525541 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
李白你好2 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
刘一说3 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
徐同保4 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
刘一说4 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
一周七喜h5 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js
weixin_395448915 小时前
main.c_cursor_0202
前端·网络·算法
东东5165 小时前
基于vue的电商购物网站vue +ssm
java·前端·javascript·vue.js·毕业设计·毕设
MediaTea6 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
梦梦代码精6 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱