首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
开篇:用正确的方式学习 TypeScript
打造 TypeScript 的开发环境
TypeScript中的原始类型与对象类型
TypeScript中的字面量类型与枚举
TypeScript中的函数重载与面向对象
TypeScript的内置类型:any、unknown、never 与类型断言
TypeScript 类型工具
TypeScript 中无处不在的泛型
TypeScript 类型系统层级:从 Top Type 到 Bottom Type
TypeScript 类型里的逻辑运算:条件类型与 infer
TypeScript 中的内置工具类型基础
TypeScript 反方向类型推导:用好上下文相关类型
TypeScript 函数类型:协变与逆变的比较
TypeScript中类型编程与类型体操的意义
TypeScript模板字符串类型
TypeScript模板字符串工具类型进阶
TypeScript类型声明、类型指令与命名空间
在 React 中愉快地使用 TypeScript:内置类型与泛型坑位
让 ESLint 来约束你的 TypeScript 代码:配置与规则集介绍
TypeScript装饰器与反射元数据
TypeScript控制反转与依赖注入
TSConfig 全解(上):构建相关配置
TSConfig 全解(下):检查相关、工程相关配置
当前位置:
首页>>
技术小册>>
TypeScript入门指南
小册名称:TypeScript入门指南
TypeScript是一种静态类型的编程语言,它提供了一些高级类型工具,如条件类型和infer关键字,使得类型系统更加灵活和强大。本章节将重点介绍条件类型和infer关键字在TypeScript中的使用,并通过代码示例演示它们的具体应用。 ----------------------------- **1、条件类型** 条件类型是一种可以根据类型关系条件性地选择另一种类型的工具。它通常用于泛型类型的约束,以根据泛型类型的具体类型参数来选择不同的类型。 **基本语法** 条件类型的基本语法如下: ```javascript T extends U ? X : Y ``` 其中,T和U是两种类型,X和Y是两种备选类型。当T可以赋值给U时,条件类型的值为X,否则为Y。 **示例** 我们来看一个简单的例子,实现一个泛型函数trim,将字符串去除两端的空格。如果参数是字符串类型,则直接调用trim()方法;如果是其他类型,则返回原值。 ```javascript type IsString<T> = T extends string ? true : false; function trim<T extends string | number>(value: T): IsString<T> extends true ? string : T { return typeof value === 'string' ? value.trim() : value; } console.log(trim(' hello ')); // 'hello' console.log(trim(123)); // 123 ``` 在上面的代码中,我们定义了一个条件类型IsString<T>,它用于判断类型T是否是字符串类型。如果T是字符串类型,则条件类型的值为true,否则为false。 在trim函数中,我们使用了泛型类型T extends string | number来约束参数的类型。接着使用了条件类型,当IsString<T>为true时,返回string类型的结果;否则返回T类型的结果。这样,我们就实现了一个能够处理字符串和其他类型的函数。 **嵌套条件类型** 条件类型可以进行嵌套,以实现更加复杂的类型逻辑。 ```javascript type NonNullable<T> = T extends null | undefined ? never : T; type Flatten<T> = T extends Array<infer U> ? Flatten<U> : T; type MyType = { a?: number[], b: string } | null; type MyTypeWithoutNull = NonNullable<MyType>; type MyTypeFlatten = Flatten<MyType>; // MyTypeWithoutNull 的类型为 { a?: number[], b: string } // MyTypeFlatten 的类型为 number | string ``` 在上面的例子中,我们定义了两个条件类型。NonNullable<T>用于判断类型T是否为null或undefined类型,如果是,则返回never类型,否则返回T本身。Flatten<T>用于将嵌套的数组类型展开成一维数组。在定义Flatten<T>时,我们使用了infer关键字,它表示要推断的类型,用于获取数组元素的类型。 我们还定义了一个复杂的类型MyType,它可以是一个MyType类型为{ a?: number[], b: string }或null类型。我们使用NonNullable<MyType>来移除null类型,得到{ a?: number[], b: string }类型。接着使用Flatten<MyType>来展开数组类型,得到number | string类型。这样,我们就可以通过条件类型和嵌套类型的组合,处理更加复杂的类型逻辑。 **2、infer关键字** infer是TypeScript 2.8版本中引入的一个新关键字,用于推断类型变量的类型。它通常用于条件类型的右侧,以获取泛型类型的具体类型参数。 **基本语法** infer的基本语法如下: ```javascript T extends (infer U)[] ? U : never ``` 其中,T extends (infer U)[]表示T是一个数组类型,并将数组元素类型赋值给类型变量U。U即为要推断的类型变量,可以在条件类型的其他地方使用。如果T不是数组类型,则返回never类型。 **示例** 我们来看一个示例,实现一个泛型函数head,返回数组的第一个元素。我们使用infer关键字来获取数组元素的类型。 ```javascript function head<T extends any[]>(arr: T): T extends [infer U, ...any[]] ? U : never { return arr[0]; } const arr1 = [1, 2, 3]; const arr2 = ['a', 'b', 'c']; const arr3 = []; console.log(head(arr1)); // 1 console.log(head(arr2)); // 'a' console.log(head(arr3)); // never ``` 在上面的代码中,我们使用泛型类型T extends any[]来约束参数的类型,表示参数必须是一个数组类型。接着使用条件类型T extends [infer U, ...any[]] ? U : never,表示当T是一个非空数组类型时,返回数组第一个元素的类型;否则返回never类型。在条件类型中,我们使用了infer关键字来获取数组元素的类型。 通过上面的示例,我们可以看到,infer关键字可以方便地获取泛型类型的具体类型参数,使得类型系统更加灵活和强大。 **小结** 本文介绍了TypeScript中的条件类型和infer关键字,以及它们的基本语法和应用场景。通过使用这些高级类型工具,我们可以更加方便地实现复杂的类型逻辑,提高代码的可读性和可维护性。
上一篇:
TypeScript 类型系统层级:从 Top Type 到 Bottom Type
下一篇:
TypeScript 中的内置工具类型基础
该分类下的相关小册推荐:
TypeScript 全面进阶指南
剑指TypeScript
TypeScript开发实战