基于typeof参数值的返回类型

时间:2020-01-13 20:27:52

标签: javascript typescript types

我正在创建一个函数,该函数带有两个参数key和一个值cast的结果。因此,我创建了一个type来限制可以将项目强制转换为的值。我也希望这是返回类型,但是基于EnvCast,它以typeof为前缀,因此我使用它的方式表示应该返回{{1} }。

如何基于typeof x的值返回类型?因此,如果cast的返回类型将是cast('my_key', Number)而不是Number?。

typeof Number

编辑:

我想我可以做这样的事情(没有这种方法是否可以做到)?

declare type EnvCast = typeof Number | typeof Boolean | typeof String;

export function env<T extends EnvCast>(key: string, cast?: EnvCast): T {
    const result = (process.env[key] ? process.env[key] : '') as string;
    if (!cast) { return result; }
    return cast(result);
}

3 个答案:

答案 0 :(得分:2)

cast参数类型可以由扩展C的类型参数EnvCast表示。然后,env函数返回ReturnType<C>,它基本上是number | boolean | stringInstanceType<C>将给我们原始的盒装类型,它是no good):

export function env<C extends EnvCast>(key: string, cast?: C): ReturnType<C> {
  const result = (process.env[key] ? process.env[key] : '') as string;
  if (!cast) { throw new Error() /* or something else you want to do here */ }
  return cast(result) as ReturnType<C>;
}

const r1 = env("myKey", Number) // number
const r2 = env("myKey", Boolean) // boolean
const r3 = env("myKey", String) // string
const r4 = env("myKey", Array) // error
const r5 = env("myKey", Date) // error

Sample

答案 1 :(得分:0)

如何使用generic函数

function env<T>(key: string, cast: T): T {

}

用法将是这样

const x = env<number>('' , 10); // x will be of type number

答案 2 :(得分:0)

有些不同的方法,如果我理解您的要求,这可能会起作用:

declare type EnvCast = Number | Boolean | String;
export function env<T extends EnvCast>(key: string, cast?: (string)=>T):T {
    const result = (process.env[key] ? process.env[key] : '') as string;
    return cast(result);
}
const x= env('42',Number)  //x is number here