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入门之配置文件

后记

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

相关文章
|
10天前
|
JavaScript
typeScript进阶(9)_type类型别名
本文介绍了TypeScript中类型别名的概念和用法。类型别名使用`type`关键字定义,可以为现有类型起一个新的名字,使代码更加清晰易懂。文章通过具体示例展示了如何定义类型别名以及如何在函数中使用类型别名。
27 1
typeScript进阶(9)_type类型别名
|
10天前
|
JavaScript
typeScript基础(2)_any任意值类型和类型推论
本文介绍了TypeScript中的`any`任意值类型,它可以赋值为其他任何类型。同时,文章还解释了TypeScript中的类型推论机制,即在没有明确指定类型时,TypeScript如何根据变量的初始赋值来推断其类型。如果变量初始化时未指定类型,将被推断为`any`类型,从而允许赋予任何类型的值。
27 4
|
10天前
|
JavaScript
typeScript基础(5)_对象的类型-interfaces接口
本文介绍了TypeScript中接口(interfaces)的基本概念和用法,包括如何定义接口、接口的简单使用、自定义属性、以及如何使用`readonly`关键字定义只读属性。接口在TypeScript中是定义对象形状的重要方式,可以规定对象的必有属性、可选属性、自定义属性和只读属性。
26 1
|
10天前
|
存储 JavaScript
typeScript进阶(11)_元组类型
本文介绍了TypeScript中的元组(Tuple)类型,它是一种特殊的数组类型,可以存储不同类型的元素。文章通过示例展示了如何声明元组类型以及如何给元组赋值。元组类型在定义时需要指定数组中每一项的类型,且在赋值时必须满足这些类型约束。此外,还探讨了如何给元组类型添加额外的元素,这些元素必须符合元组类型中定义的类型联合。
21 0
|
10天前
|
JavaScript
typeScript进阶(10)_字符串字面量类型
本文介绍了TypeScript中的字符串字面量类型,这种类型用来限制变量只能是某些特定的字符串字面量。通过使用`type`关键字声明,可以确保变量的值限定在预定义的字符串字面量集合中。文章通过示例代码展示了如何声明和使用字符串字面量类型,并说明了它在函数默认参数中的应用。
22 0
|
10天前
|
JavaScript 前端开发
typeScript基础(8)_ts类型断言
本文介绍了TypeScript中的类型断言,它用于在编译时告诉TypeScript某个对象具有特定的类型,即使它看起来不具备。类型断言可以用来访问一个类型上存在而另一个类型上不存在的属性或方法。需要注意的是,类型断言并不会在运行时改变JavaScript的行为,因此如果断言不当,运行时仍然可能出错。文章还提醒避免将类型断言为`any`类型或进行多重断言。
12 1
|
10天前
|
JavaScript
typeScript基础(6)_数组类型
本文介绍了TypeScript中数组的类型表示方法,包括直接使用类型加`[]`定义数组类型,以及使用数组泛型`Array<类型>`定义数组。同时,还展示了如何定义包含多种数据类型的数组。
24 1
|
8天前
|
JavaScript 前端开发 编译器
TypeScript,从0到入门带你进入类型的世界
该文章提供了TypeScript的入门指南,从安装配置到基础语法,再到高级特性如泛型、接口等的使用,帮助初学者快速掌握TypeScript的基本用法。
|
10天前
|
JavaScript
typeScript基础(7)_函数的类型
本文介绍了TypeScript中函数的类型,包括函数声明与函数表达式的类型注解,如何定义函数的参数类型、返回类型,以及可选参数和参数默认值。还探讨了函数的剩余参数、如何使用接口定义函数的形状,以及函数重载的概念和实践。
10 0
|
3月前
|
前端开发 JavaScript 安全
TypeScript在React Hooks中的应用:提升React开发的类型安全与可维护性
【7月更文挑战第17天】TypeScript在React Hooks中的应用极大地提升了React应用的类型安全性和可维护性。通过为状态、依赖项和自定义Hooks指定明确的类型,开发者可以编写更加健壮、易于理解和维护的代码。随着React和TypeScript的不断发展,结合两者的优势将成为构建现代Web应用的标准做法。
下一篇
无影云桌面