假设我们有以下输入类型:
interface Input {
name: string;
heightCm: number;
dob: Date;
}
我想编写一个函数,可以根据此输入生成以下输出类型:
interface Output {
name: boolean;
heightCm: boolean;
dob: boolean;
}
换句话说,一个函数复制输入的结构并将该结构作为输出返回,将所有值设置为 bool 值。
函数签名看起来像这样:
interface GenericMap<T> {
[key: string]: T;
}
type InputToOutput<In, Out extends GenericMap<boolean>> = (input: In) => Out;
如果 Input
属性的类型最初是字符串,则将该属性标记为 true
,否则标记为 false
。
例如该函数将根据上面的 Input
产生以下结果:
{
name: true,
heightCm: false,
dob: false
}
但最重要的是,它必须是类型安全的,这样我才能接收到结果对象的智能感知。
非常感谢帮助!
最佳答案
我认为您只需要一个将每个属性的类型设置为 bool 值的映射类型?
type GenericMap<T> = {
[K in keyof T]: boolean
}
你会这样使用:
interface Input {
name: string;
heightCm: number;
dob: Date;
}
type Output = GenericMap<Input>
// Output is
// {
// name: boolean;
// heightCm: boolean;
// dob: boolean;
// }
作为(潜在的)改进,您甚至可以检查此类型别名中的 string
并返回 true
或 false
,而不是 bool 值
。
type GenericMap<T> = {
[K in keyof T]: T[K] extends string ? true : false
}
哪个会产生这种类型:
type Output = GenericMap<Input>
// {
// name: true;
// heightCm: false;
// dob: false;
// }
关于javascript - 如何在 TypeScript 中将一个泛型类型的结构复制到另一个泛型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68105392/