0

0

理解 TypeScript 中的 infer 关键字

心靈之曲

心靈之曲

发布时间:2024-09-28 13:15:03

|

1438人浏览过

|

来源于dev.to

转载

理解 typescript 中的 infer 关键字

typescript 是 javascript 的静态类型超集,由于其能够及早捕获错误并提高代码可读性,在技术社区中广受欢迎。 typescript 的强大功能之一是 infer 关键字,它允许开发人员编写更具表现力和动态的类型。

推断关键字

typescript 2.8 中引入的 infer 关键字用于在条件类型中创建临时类型变量。然后,这些类型变量可用于推断条件类型的 true 或 false 分支内的类型。 infer 关键字使开发人员能够编写更具动态性和表现力的类型,因为它允许 typescript 根据使用的上下文确定特定类型。

为了更好地理解 infer 的工作原理,我们来看看条件类型的基本语法:

type myconditionaltype = t extends sometype ? truetype : falsetype;

在此示例中,t 是泛型类型参数,sometype 表示与 t 进行比较的类型。如果 t 扩展 sometype,则 myconditionaltype 的类型将为 truetype。如果不是,它将是 falsetype。

现在,让我们将 infer 关键字引入其中:

type myinferredtype = t extends sometype ? u : falsetype;

在这里,我们使用 infer 关键字在条件类型的 true 分支内创建一个临时类型变量 u。如果 t 扩展 sometype,typescript 将尝试根据 t 的类型推断 u 的类型。

示例

返回类型

returntype 是一种提取函数返回类型的实用程序类型。这是如何使用 infer 关键字创建动态类型的完美示例。这是 returntype 的定义:

type returntype any> = t extends (...args: any[]) => infer r ? r : any;

在此定义中,t 是一个函数类型,它接受任意数量的参数并返回任意类型。使用 infer 关键字,我们创建一个临时类型变量 r 来表示函数的返回类型。如果 t 是函数,typescript 会推断返回类型并将其分配给 r。

让我们看看 returntype 的实际效果:

function greet(name: string): string {
  return `hello, ${name}!`;
}
​
type greetreturntype = returntype; // greetreturntype is inferred as 'string'

这里,returntype用于推断greet函数的返回类型,即string。

参数

利用 infer 关键字的另一个有用的实用程序类型是参数。该类型将函数的参数类型提取为元组。参数定义如下:

type parameters any> = t extends (...args: infer p) => any ? p : never;

在这个例子中,我们创建一个临时类型变量 p 来表示函数的参数类型。如果 t 是函数,typescript 会推断参数类型并将它们作为元组分配给 p。

让我们看一个使用参数的示例:

衣购网站项目(三层开发)源码
衣购网站项目(三层开发)源码

商品查询功能提供了一个快速查看商品的途径。商品查询分为基本查询和高级查询。基本查询:提供关键字和商品大类两种条件的查询,用户可以只填写关键字或者选择商品大类或者关键字和商品大类都填写来查询商品。高级查询:提供关键字,商品大类,商品小类,商品价格范围四种条件的查询,用户可以任意填写其中一种或几种的查询条件来查询想要了解的商品信息。商品查询功能大大的方便了用户,提高了网站的用户体验。(5)帮助系统模块

下载
function add(a: number, b: number): number {
  return a + b;
}
​
type addparameters = parameters; // addparameters is inferred as [number, number]

这里的parameters用于推断add函数的参数类型,是一个元组[number, number]。

promisetype

promisetype 实用程序类型可用于提取 promise 解析为的类型。这在处理异步函数时特别有用。这是 promisetype 的定义:

type promisetype> = t extends promise ? u : never;

在此示例中,我们创建一个临时类型变量 u 来表示 promise 解析为的类型。如果 t 是 promise,typescript 会推断已解析的类型并将其分配给 u。这是一个示例:

async function fetchdata(): promise {
  return "fetched data";
}
​
type fetcheddatatype = promisetype>; // fetcheddatatype is inferred as 'string'

在本例中,promisetype 用于推断 fetchdata 函数的 promise 解析的类型,即字符串。

unboxarray

unboxarray 实用程序类型可用于提取数组中元素的类型。这是 unboxarray 的定义:

type unboxarray> = t extends array ? u : never;

在此示例中,我们创建一个临时类型变量 u 来表示数组中元素的类型。如果 t 是一个数组,typescript 会推断元素类型并将其分配给 u。例如:

type MyArray = number[];

type ElementType = UnboxArray; // ElementType is inferred as 'number'

这里,unboxarray 用于推断 myarray 类型内元素的类型,即 number。

局限性

虽然 infer 关键字非常强大,但它也有一些限制:

  1. 它只能在条件类型中使用。

  2. typescript 并不总是能够推断出正确的类型,尤其是在处理复杂或递归类型时。在这种情况下,开发人员可能需要提供额外的类型注释或重构其类型以帮助 typescript 推断正确的类型。

结论

通过理解和利用 infer 的力量,您可以创建更灵活的 typescript 项目。立即开始考虑将 infer 关键字合并到您的工具包中。

如果您发现这有帮助,请考虑 订阅我的时事通讯 以获取更多有关 web 开发的有用文章和工具。感谢您的阅读!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

624

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

653

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

172

2025.07.29

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

0

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3.1万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号