简而言之,我想要一个采用非预定义类型的函数,如下所示:
{
name: string,
list: Array,
metadata: Object,
}
并返回这个
{
name: MyStringProxy,
list: MyArrayProxy,
metadata: MyObjectProxy,
}
我知道如何返回一个对象,其中每个属性都具有相同的类型(对象与打字稿中的另一个对象具有相同的键?)...
abstract function allPropsAre42<TYPE_IN>(obj: TYPE_IN): { [key in keyof TYPE_IN]: 42 };
...这是一个很好的起点,但它只将所有内容映射到一种类型。我想将每种类型映射到另一种类型。
我很确定这是不可能的,但这里有一些虚构的伪代码,就像我正在寻找的那样:
interface IPropMap {
string: MyStringProxy,
Array: MyListProxy,
Object: MyObjectProxy,
}
// not real code
abstract function mapAllProps<TYPE_IN>(obj: TYPE_IN): {
[key in keyof TYPE_IN]: IPropMap[TYPE_IN[key]]
};
有可能在打字稿中做这样的事情吗?
https://www.typescriptlang.org/docs/handbook/advanced-types.html#conditional-types
弄清楚了。使用条件类型映射,可以做到:
type TypeName<T> =
T extends string ? MyStringProxy :
T extends Array ? MyArrayProxy :
T extends object ? MyObjectProxy :
undefined;
abstract function mapAllProps<TYPE_IN>(obj: TYPE_IN): {
[key in keyof TYPE_IN]: TypeName[TYPE_IN[key]]
};
我的猜测并不太远。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句