TypeScript入门之常用内置工具类型

简介: 常用内置工具类型

简介

TypeScript 提供一些工具类型来帮助常见的类型转换,这些类型是全局可用。在使用时我们可以直接调用。

Exclude<T, U> 从 T 可分配给的类型中排除 U

可以简单理解为排除一个联合类型中的某些类型。

type Exclude<T, U> = T extends U ? never : T;

使用

type E1 = Exclude<string | number, string>; // 排除string剩下number

所以E就是number

image.png

let e: E1 = 10; // 这里的E就是number类型

当然它也是支持排除多个的

type E5 = Exclude<string | number | boolean, string | boolean>; // 排除string和boolean剩下number

image.png

Extract<T,U> 从 T 可分配给的类型中提取 U

可以简单理解为提取一个联合类型中的某些类型。

type Extract<T, U> = T extends U ? T : never;

使用

type E2 = Extract<string | number, string>; // 提取string

所以E就是string

image.png

let e: E2 = "1"; // 这里的E就是string类型

当然它也是支持提取多个的

type E6 = Extract<string | number | boolean, string | boolean>; // 提取string和boolean

image.png

NonNullable 从 T 中排除 nullundefined

可以简单理解为踢出一个联合类型中的nullundefined

type NonNullable<T> = T extends null | undefined ? never : T;

使用

type E3 = NonNullable<string | number | null | undefined>;

所以E就是string | number

image.png

let e1: E3 = 1;
let e2: E3 = '1';

ReturnType 表示在 extends 条件语句中待推断的类型变量

该工具类型主要是获取函数类型的返回值类型。

type ReturnType<T extends (...args: any[]) => any> = T extends (
  ...args: any[]
) => infer R
  ? R
  : any;
  

使用

function getUserInfo() {
  return { name: "randy", age: 24 };
}

// 通过 ReturnType 将 getUserInfo 的返回值类型赋给了 E4
type E4 = ReturnType<typeof getUserInfo>;

image.png

const userA: E4 = {
  name: "hello",
  age: 10,
};

Parameters 获取函数类型的参数类型

type Parameters<T> = T extends (...args: infer R) => any ? R : any;

使用

type T0 = Parameters<() => string>; // []
type T1 = Parameters<(s: string) => void>; // [string]
type T2 = Parameters<<T>(arg: T) => T>; // [unknown]

Partial 可以将传入的属性由必选变为可选

type Partial<T> = { [P in keyof T]?: T[P] };

使用

interface A {
  a1: string;
  a2: number;
  a3: boolean;
}

type aPartial = Partial<A>;

image.png

const a: aPartial = {}; // 不会报错

Required 可以将传入的属性中的可选项变为必选项,这里用了 -? 修饰符来实现。

type Required<T> = { [P in keyof T]-?: T[P] };

使用

interface Person {
  name: string;
  age: number;
  gender?: "male" | "female";
}

type p = Required<Person>

const person: p = {
  name: 'randy',
  age: 24,
  gender: 'male'
}

image.png

Readonly 通过为传入的属性每一项都加上 readonly 修饰符来实现。

type Readonly<T> = { readonly [P in keyof T]: T[P] };

使用

interface Person {
  name: string;
  age: number;
  gender?: "male" | "female";
}

type p2 = Readonly<Person>;

const person4: p2 = {
  name: "randy",
  age: 24,
};
person4.name = "demi"; // error

image.png

Pick<T, K> 能够帮助我们从传入的属性中摘取某些返回

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

使用

interface Todo {
  title: string;
  description: string;
  done: boolean;
}

type TodoBase = Pick<Todo, "title" | "done">;

const todo1: TodoBase = {
  title: "todo1",
  done: true,
};

image.png

Record<K, T> 构造一个类型,该类型具有一组属性 K,每个属性的类型为 T。

可用于将一个类型的属性映射为另一个类型。Record 后面的泛型就是对象键和值的类型。

简单理解:K 对应对象的 keyT 对应对象的 value,返回的就是一个声明好的对象 但是 K 对应的泛型约束是keyof any 也就意味着只能传入 string|number|symbol

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

使用

type Point = "x" | "y";

type PointList = Record<Point, { value: number }>;

可以看到PointListkey"x" | "y"value{ value: number }

image.png

const cars: PointList = {
  x: { value: 10 },
  y: { value: 20 },
};

Omit<K, T> 基于已经声明的类型进行属性剔除获得新类型

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

使用

type User8 = {
  id: string;
  name: string;
  email: string;
};

type UserWithoutEmail = Omit<User8, "email">; // UserWithoutEmail ={id: string;name: string;}

我们可以看到,UserWithoutEmailemial踢出了。

image.png

const user9: UserWithoutEmail = {
  id: "1",
  name: "randy",
};

infer

infer 是工具类型和底层库中非常常用的关键字,表示在 extends 条件语句中待推断的类型变量。

这个概念可能看不太懂,下面笔者举个例子就明白了。

假如想在获取数组里的元素类型,在不会infer之前我是这样做的:

type Ids = number[];
type Names = string[];

type Unpacked<T> = T extends Names ? string : T extends Ids ? number : T;

type idType = Unpacked<Ids>; // idType 类型为 number
type nameType = Unpacked<Names>; // nameType 类型为string

然而如果使用infer,会变得十分简单。

type ElementOf<T> = T extends Array<infer E> ? E : T;

type Tuple = string[];

type TupleToUnion = ElementOf<Tuple>; // string
type TupleToUnion2 = ElementOf<number[]>; // number

如果T是某个待推断类型的数组,则返回推断的类型,否则返回T

系列文章

TypeScript入门之环境搭建

TypeScript入门之数据类型

TypeScript入门之函数

TypeScript入门之接口

TypeScript入门之类

TypeScript入门之类型推断、类型断言、双重断言、非空断言、确定赋值断言、类型守卫、类型别名

TypeScript入门之泛型

TypeScript入门之装饰器

TypeScript入门之模块与命名空间

TypeScript入门之申明文件

TypeScript入门之常用内置工具类型

TypeScript入门之配置文件

后记

感谢小伙伴们的耐心观看,本文为笔者个人学习笔记,如有谬误,还请告知,万分感谢!如果本文对你有所帮助,还请点个关注点个赞~,您的支持是笔者不断更新的动力!

相关文章
|
1月前
|
前端开发 JavaScript 安全
TypeScript在React Hooks中的应用:提升React开发的类型安全与可维护性
【7月更文挑战第17天】TypeScript在React Hooks中的应用极大地提升了React应用的类型安全性和可维护性。通过为状态、依赖项和自定义Hooks指定明确的类型,开发者可以编写更加健壮、易于理解和维护的代码。随着React和TypeScript的不断发展,结合两者的优势将成为构建现代Web应用的标准做法。
|
7天前
|
JavaScript
TypeScript——不能将类型“HTMLElement | null”分配给类型“HTMLElement”
TypeScript——不能将类型“HTMLElement | null”分配给类型“HTMLElement”
19 4
|
12天前
|
JavaScript 编译器
typescript 解决变量多类型访问属性报错--工作随记
typescript 解决变量多类型访问属性报错--工作随记
|
19天前
|
开发框架 前端开发 JavaScript
基于SqlSugar的开发框架循序渐进介绍(18)-- 基于代码生成工具Database2Sharp,快速生成Vue3+TypeScript的前端界面和Winform端界面
基于SqlSugar的开发框架循序渐进介绍(18)-- 基于代码生成工具Database2Sharp,快速生成Vue3+TypeScript的前端界面和Winform端界面
|
6天前
|
JavaScript
TypeScript——Record类型
TypeScript——Record类型
14 0
|
12天前
|
JavaScript 前端开发 编译器
Typescript 回调函数、事件侦听的类型定义与注释--拾人牙慧
Typescript 回调函数、事件侦听的类型定义与注释--拾人牙慧
|
1月前
|
JavaScript 开发者 索引
TypeScript接口与类型别名:深入解析与应用实践
【7月更文挑战第10天】TypeScript的接口和类型别名是定义类型的关键工具。接口描述对象结构,用于类、对象和函数参数的形状约束,支持可选、只读属性及继承。类型别名则为复杂类型提供新名称,便于重用和简化。接口适合面向对象场景,类型别名在类型重用和复杂类型简化时更有优势。选择时要考虑场景和灵活性。
|
1月前
|
JavaScript 前端开发 程序员
Typescript 【实用教程】(2024最新版)含类型声明,类型断言,函数,接口,泛型等
Typescript 【实用教程】(2024最新版)含类型声明,类型断言,函数,接口,泛型等
37 0
|
1月前
|
JavaScript 安全
TypeScript(十一)泛型工具类型
TypeScript(十一)泛型工具类型
24 0
|
1月前
|
JavaScript 前端开发 编译器
TypeScript(五)类型别名及类型符号
TypeScript(五)类型别名及类型符号
27 0