首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

将类型分配给Typescript中泛型映射函数的参数

在Typescript中,我们可以使用泛型映射函数来将类型分配给函数的参数。泛型映射函数是一种可以接受不同类型参数并返回相应结果的函数。通过使用泛型映射函数,我们可以在编译时确保参数的类型正确性。

下面是一个示例代码:

代码语言:txt
复制
type TypeName<T> =
  T extends string ? "string" :
  T extends number ? "number" :
  T extends boolean ? "boolean" :
  T extends undefined ? "undefined" :
  T extends Function ? "function" :
  "object";

function getTypeName<T>(param: T): TypeName<T> {
  return typeof param as TypeName<T>;
}

console.log(getTypeName("Hello"));  // Output: "string"
console.log(getTypeName(123));  // Output: "number"
console.log(getTypeName(true));  // Output: "boolean"
console.log(getTypeName(undefined));  // Output: "undefined"
console.log(getTypeName(() => {}));  // Output: "function"
console.log(getTypeName({}));  // Output: "object"

在上述代码中,我们定义了一个TypeName类型,它根据传入的泛型参数T来确定对应的类型名称。然后,我们定义了getTypeName函数,该函数使用泛型参数T来接受参数,并使用条件类型来确定参数的类型名称。最后,我们通过调用getTypeName函数并传入不同类型的参数来获取相应的类型名称。

这个泛型映射函数的应用场景是在需要根据不同类型参数来执行不同逻辑的情况下,可以根据参数的类型来进行相应的处理。例如,在进行类型检查、类型转换或执行不同的操作时,可以使用泛型映射函数来动态确定参数的类型。

推荐的腾讯云相关产品和产品介绍链接地址:

请注意,以上推荐的腾讯云产品仅供参考,具体选择应根据实际需求和情况进行决策。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 【TypeScript 演化史 — 第一章】non-nullable 的类型

    在这篇文章中,我们将讨论发布于 TypeScript 2.0 中的 non-nullable 类型,这是对类型系统的一个重大的改进,该特性可对 null 和 undefined 的检查。cannot read property 'x' of undefined 和 undefined is not a function 在 JS 中是非常常见的错误,non-nullable 类型可以避免此类错误。 null 和 undefined 的值 在 TypeScript 2.0 之前,类型检查器认为 null 和 undefined 是每种类型的有效值。基本上,null 和 undefined 可以赋值给任何东西。这包括基本类型,如字符串、数字和布尔值: let name: string; name = "Marius"; // OK name = null; // OK name = undefined; // OK let age: number; age = 24; // OK age = null; // OK age = undefined; // OK let isMarried: boolean; isMarried = true; // OK isMarried = false; // OK isMarried = null; // OK isMarried = undefined; // OK 以 number 类型为例。它的域不仅包括所有的IEEE 754浮点数,而且还包括两个特殊的值 null 和 undefined 对象、数组和函数类型也是如此。无法通过类型系统表示某个特定变量是不可空的。幸运的是,TypeScript 2.0 解决了这个问题。 严格的Null检查 TypeScript 2.0 增加了对 non-nullable 类型的支持,并新增严格 null 检查模式,可以通过在命令行上使用 ——strictNullChecks 标志来选择进入该模式。或者,可以在项目中的 tsconfig.json 文件启用 strictnullcheck 启用。 { "compilerOptions": { "strictNullChecks": true // ... } } 在严格的 null 检查模式中,null 和 undefined 不再分配给每个类型。null 和undefined 现在都有自己的类型,每个类型只有一个值

    02
    领券