0

0

TypeScript类型推断的迷惑之处:四种等效的ReturnType类型定义及条件类型与联合类型匹配的难题?

聖光之護

聖光之護

发布时间:2025-03-16 09:56:01

|

241人浏览过

|

来源于php中文网

原创

typescript 类型推断的迷惑:四种等效的 returntype 类型定义及条件类型与联合类型匹配的挑战

本文深入探讨 TypeScript 中一些令人费解的类型推断行为。我们将分析四种看似不同的类型定义,解释它们为何最终产生相同的结果,并解决一个与条件类型和联合类型匹配相关的难题。

首先,让我们观察这四种 getReturnType 类型定义:

type getReturnType1 = T extends (...args: never) => infer R ? R : never;

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

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

type getReturnType4 = T extends (...args: any) => infer R ? R : never;

表面上,这四种定义在函数参数 args 的类型上有所区别nevernever[]any[]any。然而,在 TypeScript 的类型推断机制下,它们的结果完全一致。这是因为在条件类型 T extends (...args: TArgs) => infer R 中,...args 主要用于匹配函数参数的数量和类型,而不会影响返回值类型 R 的推断。无论 args 的类型为何,只要 T 是函数类型,infer R 都会准确推断出函数的返回值类型。因此,这四种定义在实际应用中是等效的。

接下来,我们分析第二个问题,关于条件类型和联合类型的匹配:

图星人
图星人

好用的AI生图工具,百万免费商用图库

下载
type Props = {
  labels: T[];
  setSelect: (index: number, label: T) => void;
  xxx: any; // 保留原有代码
};

const changeSelect = (
  index: number,
  label: Major | ResCategoryLabel,
  e: React.MouseEvent | React.TouchEvent
) => {
  //  setSelect(index, label); // 原代码此处报错
  const props = {labels: [label], setSelect: (i, l) => {}} as Props; // 添加类型断言
  props.setSelect(index, label); // 使用类型断言后的 Props
  activeTabToCenter(e.currentTarget as HTMLElement);
};

这段代码中,setSelect 函数的参数 label 的类型定义为 T,依赖于泛型 T。其初衷是根据 T 的类型来确定 label 的类型。然而,在 changeSelect 函数中,label 的类型是 Major | ResCategoryLabel,这与 setSelect 函数参数类型在某些情况下不匹配,导致 TypeScript 报错。

问题在于,TProps 类型定义中是一个泛型类型,其具体类型只有在 Props 被使用时才能确定。changeSelect 函数调用 setSelect 时,T 的类型是未知的,TypeScript 无法在编译时确定 label 的具体类型。

解决方法是:在 changeSelect 函数中更精确地指定 label 的类型,或者修改 setSelect 的类型定义。 简单的 // @ts-ignore 并非最佳实践,因为它掩盖了潜在问题,不利于代码的可维护性和可读性。 上面的例子通过类型断言的方式解决了这个问题,明确指定了Props泛型类型T。 这需要根据实际情况选择合适的解决方法,确保类型安全。

TypeScript类型推断的迷惑之处:四种等效的ReturnType类型定义及条件类型与联合类型匹配的难题?

相关专题

更多
c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

22

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

24

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

99

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

132

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

15

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

65

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

63

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.22

热门下载

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

精品课程

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

共19课时 | 2.4万人学习

TypeScript——十天技能课堂
TypeScript——十天技能课堂

共21课时 | 1.1万人学习

TypeScript-45分钟入门
TypeScript-45分钟入门

共6课时 | 0.5万人学习

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

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