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

后记

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

相关文章
|
16天前
|
前端开发 JavaScript 开发者
前端项目代码规范工具 (ESLint. Prettier. Stylelint. TypeScript)
前端项目代码规范工具 (ESLint. Prettier. Stylelint. TypeScript)
|
2月前
|
设计模式 JavaScript 安全
TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等
本文深入探讨了TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等,旨在帮助开发者在保证代码质量的同时,实现高效的性能优化,提升用户体验和项目稳定性。
47 6
|
2月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
43 2
|
2月前
|
JavaScript 安全 前端开发
TypeScript类型声明:基础与进阶
通过本文的介绍,我们详细探讨了TypeScript的基础与进阶类型声明。从基本数据类型到复杂的泛型和高级类型,TypeScript提供了丰富的工具来确保代码的类型安全和可维护性。掌握这些类型声明能够帮助开发者编写更加健壮和高效的代码,提高开发效率和代码质量。希望本文能为您在使用TypeScript时提供实用的参考和指导。
40 2
|
2月前
|
JavaScript 开发者
在 Babel 插件中使用 TypeScript 类型
【10月更文挑战第23天】可以在 Babel 插件中更有效地使用 TypeScript 类型,提高插件的开发效率和质量,减少潜在的类型错误。同时,也有助于提升代码的可理解性和可维护性,使插件的功能更易于扩展和升级。
|
3月前
|
JavaScript 前端开发
TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第11天】TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
3月前
|
JavaScript 前端开发 安全
TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第9天】TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
3月前
|
JavaScript 前端开发 开发者
深入理解TypeScript:类型系统与最佳实践
【10月更文挑战第8天】深入理解TypeScript:类型系统与最佳实践
|
3月前
|
移动开发 JavaScript 前端开发
TypeScript:数组类型&函数使用&内置对象
本文介绍了 TypeScript 中的数组类型、对象数组、二维数组、函数、函数重载、内置对象等概念,并通过代码示例详细展示了它们的使用方法。还提供了一个使用 HTML5 Canvas 实现的下雨效果的小案例。
|
2月前
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
34 0