0

当我有一个接受泛型数组并返回转换后数组的函数时,我可以编写:

function myfun<T>(input: Array<T>): Array<T> {}

但是,如果数组是异构类型,这将失败,因为 T 在数组上是不同的。现在,因为我知道 T 将始终是某个基础的子类型:BaseTy并且在函数期间我只使用来自/在基础类型上操作的函数,我可以编写:

function myfun(input: Array<BaseTy>): Array<BaseTy> {}

然而,这存在实际类型“丢失”的问题,因此该数组不再是派生类型的异构数组。

这可以在不使用不安全的类型转换的情况下解决any吗?

4

1 回答 1

1

您需要使用有界泛型来指定可以接受的最小类型,同时还允许函数返回更具体的类型:

function myfun<T: BaseTy>(input: Array<T>): Array<T> {
    // whatever you want to do here
    return input
}

完整代码示例:

type BaseType = {
    base: 'whatever'
}
type TypeA = BaseType & { a: 'Foo' }
type TypeB = BaseType & { b: 'Bar' }
type TypeC = BaseType & { c: 'Baz' }

function myfun<T: BaseType>(input: Array<T>): Array<T> {
    return input
}

const a = {
  base: 'whatever',
  a: 'Foo'
}

const b = {
  base: 'whatever',
  b: 'Bar'
}

const c = {
  base: 'whatever',
  c: 'Baz'
}


const aAndBs: Array<TypeA | TypeB> = [a, b]
const aAndCs: Array<TypeA | TypeC> = [a, c]

// Correct
const xs1: Array<TypeA | TypeB> = myfun(aAndBs)

// Error - It's actually returning Array<TypeA | TypeC>
const xs2: Array<TypeA | TypeB> = myfun(aAndCs)

试试

$ReadOnlyArray就像乔丹说的那样,如果您遇到方差问题,您可能希望将输入数组的类型更改为:

function myfun<T: BaseType>(input: $ReadOnlyArray<T>): $ReadOnlyArray<T> {
    return input
}

于 2019-02-26T14:52:16.727 回答