当前位置:首页 » 《随便一记》 » 正文

【TypeScript】TS条件类型(十)

18 人参与  2023年04月12日 10:57  分类 : 《随便一记》  评论

点击全文阅读


? 个人主页:不叫猫先生
?‍♂️ 作者简介:2022年度博客之星前端领域TOP 2,前端领域优质作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
?优质专栏:vue3从入门到精通、TypeScript从入门到实践
? 资料领取:前端进阶资料以及文中源码可以找我免费领取
? 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,一起交流学习,期待你的加入!(文末有我wx或者私信)。

在这里插入图片描述

目录

条件类型一、基本用法二、分布式条件类型三、非分布式条件类型四、结合范型使用1.类型删除2.过滤出公共类型 五、结合 infer 关键字1.获取函数返回类型 六、结合keyof关键字1.获取对象属性类型2.实现映射类型 ?粉丝福利(评论赠书)

TypeScript 2.8版本引入了条件类型(Conditional Types),TS条件类型可以进行类型选择,具体用法可以使用三元运算符实现,JS中的三元运算符用法一样,通过判断得到最终结果,TS条件类型最终得到的是数据类型。

条件类型

条件类型允许根据一个或多个条件对类型进行推断,并且还能在在类型级别上进行复杂的逻辑运算和类型操作。

一、基本用法

当T类型可以赋值给U类型时,则返回X类型,否则返回Y类型。

T extends U ? X : Y

列举例子如下:

其中TypeName为条件类型,根据T的具体类型返回不同类型的字符串,也就是字面量类型。

type TypeName<T> =  T extends string ? "string" :  T extends number ? "number" :  T extends boolean ? "boolean" :  T extends undefined ? "undefined" :  T extends Function ? "function" :  "object";type A = TypeName<'1'> //"string"type B = TypeName<1> //"number"type C = TypeName<true> //"blolean"type D = TypeName<undefined> //"undefined"type E = TypeName<()=>void> //"function"type F = TypeName<{}> //"object "

当被检查类型T为联合类型时:

type G = TypeName<'1'| 1 | true> // "string" | "number" | "boolean"type H = TypeName<()=>void | {}> // "function" | "object"

二、分布式条件类型

在条件类型中,如果被检查的类型是一个 “裸” 类型参数,即没有被数组、元组或 Promise 等包装过,则该条件类型被称为分布式条件类型。当分布式条件类型中被检查类型为联合类型,则在运算过程中分解多个分支 。

type typeName<T> = T extends number ? "X" : "Y" ;type H = typeName<string | number> // "X" | "Y"//上面typeName在计算类型时,会分解为如下:type H =  string extends number ? "X" : "Y" | number extends number ? "X" : "Y" = "X" | "Y"

三、非分布式条件类型

当T被数组、元组、Promise等包裹时,则运算过程中不会分解成多个分支,则该条件类型为非分布式条件类型。

type WrappedTuple<T> = [T] extends [boolean] ? "X" : "Y";type WrappedArray<T> = T[] extends boolean[] ? "X" : "Y";type WrappedPromise<T> = Promise<T> extends Promise<boolean> ? "X" : "Y";type G = WrappedTuple<string | boolean>; // "Y"type K = WrappedArray<string | boolean>; // "Y"type L = WrappedPromise<string | boolean>; // "Y"

解析:

//由于计算数据时不会分解成多个分支// [T] extends [boolean]//WrappedTuple<string | boolean> 中 string | boolean 不是 boolean 类型,也不是其他原始类型//T[] extends boolean[]//WrappedArray<string | boolean> 中 string | boolean 不是 boolean 类型,也不是其他原始类型//Promise<T> extends Promise<boolean>//WrappedPromise<string | boolean> 中 string | boolean 不是 boolean 类型,也不是其他原始类型

四、结合范型使用

1.类型删除

在联合类型T删除联合类型U中的成员,T类型中的剩余成员则组成新的类型。下面例子中,如果类型T为类型U的子类型,则返回never,否则返回类型T

type Diff<T, U> = T extends U ? never : T;type A = Diff<"a" | "b" | "c", "a" | "c" | "d">;  // "b"

在联合类型T过滤出联合类型U中的成员,过滤出来的成员则组成新的类型。下面例子中,如果类型T为类型U的子类型,则返回类型T,否则返回never

2.过滤出公共类型

type Filter<T, U> = T extends U ? T : never;type B = Filter<"a" | "b" | "c", "a" | "c" | "d"> ; // "a" | "c"

五、结合 infer 关键字

条件类型除了可以使用extends,也可以使用infer关键字。infer 关键字可以用于从一个类型中提取另一个类型。

1.获取函数返回类型

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

定义了FunctionReturnType条件类型,它会检查类型T是否为函数类型,如果是则通过infer获取函数的返回值类型R,否则返回never类型。具体案例如下:

type FRT1 = FunctionReturnType<() => number> //numbertype FRT2 = FunctionReturnType<(x: string, y: number) => string[]> //stringtype FRT3 = FunctionReturnType<() => void>//voidtype FRT4 = FunctionReturnType<() => {}>//{}type FRT5 = FunctionReturnType<1>//never

六、结合keyof关键字

1.获取对象属性类型

keyof主要是获取某个对象/类型的属性名来构成新类型。我们可以使用条件类型和 keyof 关键字来获取对象的属性。具体案例如下:

type PropertyType<T, K extends keyof T> = K extends keyof T ? T[K] : never;

上面代码定义了类型为PropertyType<T, K extends keyof T>,通过检查K是否是T的一个属性名,如果是则返回该属性类型,否则返回never

type Obj = { a: string; b: number };type A = PropertyType<Obj, "a">; // stringtype B = PropertyType<Obj, "c">; // never

2.实现映射类型

映射类型是泛型类型的一种,可用于把原有的对象类型映射成新的对象类型。我们可以使用条件类型和 keyof关键字来实现Partial类型,Partial类型是TS工具类之一。具体案例如下:

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

定义类型Partial<T>,遍历T中所有属性,然后通过?将所有属性变成可选属性。

type obj = {a:string,b:number}type R = Partial<obj>//{a?:string,b?:number}

注意:Partial是TS的工具类,所以声明Partial是会报错的,可以换个标识符名称。

在这里插入图片描述

?粉丝福利(评论赠书)

《深入理解设计模式》
活动规则:评论区进行优质评论
抽奖规则:根据 优质评论 以及 优质评论点赞量 抽取 三人
活动时间:即日起至2023年4月11日 12:00
温馨提示:参与活动者提前参加博主wx(文末附有),以避免错过中奖通知。

在这里插入图片描述
本书系统介绍了23种设计模式,根据具体的实例形象化、具体化地进行了代码的编写和详细讲解,让那些本来对设计模式不太了解、一知半解、只有概念的读者,彻底了解和掌握常用的设计模式使用场景及使用方式,并掌握每个设计模式的UML结构和描绘方式。本书共23章,包括认识设计模式、单例模式、工厂模式、建造者模式、原型模式、适配器模式、装饰器模式、外观模式、桥接模式、组合模式、享元模式、代理模式、策略模式、命令模式、状态模式、模板方法模式、备忘录模式、中介者模式、观察者模式、迭代器模式、责任链模式、访问者模式、解释器模式。通过以上的知识,让你从模式小白直接升级为模式大神!本书所需源代码,均可通过本书配套下载链接获得。


点击全文阅读


本文链接:http://zhangshiyu.com/post/59367.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1