generics - 如何在 Typescript 中为箭头函数创建泛型类型

标签 generics typescript typescript-typings

我尝试以最接近功能的风格编写 typescript 函数。对于简单的功能,我可以写:

type A = (value: number) => string;
const a: A = value => value.toString();

但是我可以用泛型类型做什么?我怎样才能以这种简单的方式键入以下功能?
function a<T>(value: T): T {
  return value;
}

如果我尝试简单地添加一个泛型类型,它什么也没有:
type A = <T>(value: T) => T;
const a: A = value => value; // `value` implicitly has an `any` type

有什么办法吗?

最佳答案

在您的最后一个片段中:

type A = <T>(value: T) => T;
const a: A = value => value;

你告诉编译器 aA 类型,但您没有将它绑定(bind)到特定的泛型类型,这就是它使用 any 的原因.

例如,您可以像这样设置泛型类型:
const a: A = (value: string) => value;

你也可以这样做:
type A<T> = (value: T) => T;
const a: A<string> = value => value;

如果你想要a再具体一点。

如果你想要a为了保持通用性,您还需要在其上声明通用约束:
const a: A = <T>(value: T) => value;

关于generics - 如何在 Typescript 中为箭头函数创建泛型类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41875350/

相关文章:

generics - 成员(member)引用不适用于Kotlin不可变列表中的maxBy

c# - typeof 泛型和强制类型

java - Java 中具有两个泛型的方法

javascript - 实现泛型类型的 Typescript 泛型类

Typescript:使用函数数组的 ReturnType(已编辑)

swift - 具有二元运算的通用函数

javascript - Typescript:是否可以引用类型别名

typescript - 在 typescript 中打字

json - 如何正确显示对象数据以在 Angular 2 中查看

angular7 - Angular 7 中的 declarations.d.ts