此间ziweishuo 2023-11-03 22:41 采纳率: 0%
浏览 8

[key: string] typescript 为什么传入数字键不报错


function Foo<DataType extends { [key: string]: any }>(name: keyof DataType){
  return name;
}

Foo<{"name":"ss",1:string}>(1); //为什么这段没有报错,我上面设置的key为string
  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-11-04 09:23
    关注

    【以下回答由 GPT 生成】

    答案:

    在 TypeScript 中,keyof 操作符返回的类型是联合类型(string | number | symbol),它表示一个对象的所有可能键的类型。因此,当你将数字 1 作为 name 参数传递给 Foo 函数时,TypeScript 并不会报错。

    要实现传入正确的参数类型的类型检查,我们可以使用 TypeScript 中的映射类型来限制 DataType 的键类型为字符串类型。

    下面是优化后的代码示例:

    type StringKeys<T> = Extract<keyof T, string>;
    
    function Foo<DataType extends { [key: string]: any }>(name: StringKeys<DataType>){
        return name;
    }
    
    Foo<{ "name":"ss", 1: string }>(1); // 此时会报错,参数类型不匹配
    

    在上述代码中,我们定义了一个辅助类型 StringKeys<T>,它使用 TypeScript 的 Extract 泛型工具来从 T 的键类型中筛选出字符串类型。然后,在 Foo 函数的参数类型中使用了 StringKeys<DataType> 来限制传递给 name 参数的键类型为字符串类型。

    现在,当我们尝试将数字 1 作为参数传递给 Foo 函数时,TypeScript 会捕获到错误,并报告类型不匹配的错误。



    【相关推荐】



    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    评论

报告相同问题?

问题事件

  • 创建了问题 11月3日

悬赏问题

  • ¥15 Coze智能助手搭建过程中的问题请教
  • ¥15 12864只亮屏 不显示汉字
  • ¥20 三极管1000倍放大电路
  • ¥15 vscode报错如何解决
  • ¥15 前端vue CryptoJS Aes CBC加密后端java解密
  • ¥15 python随机森林对两个excel表格读取,shap报错
  • ¥15 基于STM32心率血氧监测(OLED显示)相关代码运行成功后烧录成功OLED显示屏不显示的原因是什么
  • ¥100 X轴为分离变量(因子变量),如何控制X轴每个分类变量的长度。
  • ¥30 求给定范围的全体素数p的(p-2)/p的连乘积值
  • ¥15 VFP如何使用阿里TTS实现文字转语音?