【问题标题】:Typescript generic callback type hint with generic collection带有泛型集合的 Typescript 泛型回调类型提示
【发布时间】:2017-09-26 17:14:17
【问题描述】:

我想定义一个泛型类的构造函数,它接受一个回调,该回调接受一个泛型类型的集合。虽然我可以在没有集合的情况下成功定义回调类型,但我收到集合错误。错误是“TS2371:参数初始化器只允许在函数或构造函数实现中”。

这给了我错误,但这是我想要的类型定义:

import {List} from "immutable";
export class BackendToUI<BM, UM> { 
  constructor(private backendToUI: (BM, List<UM>) => UM) {}
}

这可行,但不是我想要的类型:

export class BackendToUI<BM, UM> { 
  constructor(private backendToUI: (BM, UM) => UM) {}
}

我在UM[]Array&lt;UM&gt; 上遇到了同样的问题,所以问题不是由于不可变列表类型定义中的一些实现问题造成的。

提前定义类型也无济于事,虽然我没想到会这样:

import {List} from "immutable";
type backendToUIType<BM, UM> = (BM, List<UM>) => UM;
export class BackendToUI<BM, UM> { 
  constructor(private backendToUI: backendToUIType<BM, UM>) {}
}

有人知道如何声明这个回调类型吗?

【问题讨论】:

    标签: typescript generics callback


    【解决方案1】:

    请记住,TypeScript 中类型位置的参数名称不是可选的。你到处写这样的函数类型

    (BM, UM) => UM
    

    您需要编写参数名称

    (b: BM, u: UM) => UM
    

    例如在这里,而不是

    constructor(private backendToUI: (BM, List<UM>) => UM) {}
    

    你需要

    constructor(private backendToUI: (b: BM, u: List<UM>) => UM) {}
    

    【讨论】:

    • 另外,出于好奇,为什么 Typescript 在没有参数名称和集合的情况下编译定义?具体来说,为什么会这样编译:constructor(private backendToUI: (BM, UM) =&gt; UM) {}?
    • ...回答我自己的问题...这是因为它将 BM 和 UM 解释为参数名称而不是类型。哦!
    猜你喜欢
    • 1970-01-01
    • 2019-05-30
    • 2016-06-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-02-14
    • 1970-01-01
    相关资源
    最近更新 更多