TS索引为number报错的解决方案

在类型 "{ 1: number; 4: number; 5: number; 8: number; }" 上找不到具有类型为 "number" 的参数的索引签名

在 TypeScript 中,当你使用一个类型为 number 的表达式来索引一个对象时,该对象的索引类型必须是明确定义的。如果索引类型为 "{ 1: number; 4: number; 5: number; 8: number; }",那么只能用 1、4、5、8 这些特定的数字来作为索引,而不能使用任意的 number 类型。

要解决这个问题,你可以通过修改对象的类型定义或者使用类型断言来告诉 TypeScript 编译器确切的索引类型。以下是两种解决方法:

方法一:修改对象的类型定义

interface MyObject {
    [key: number]: number;
}

const myObject: MyObject = { 1: 10, 4: 20, 5: 30, 8: 40 };

const index: number = 1;
const value = myObject[index]; // 现在 TypeScript 将不会报错


方法二:使用类型断言

const myObject: { [key: number]: number } = { 1: 10, 4: 20, 5: 30, 8: 40 };

const index: number = 1;
const value = myObject[index as keyof typeof myObject]; // 使用类型断言告诉 TypeScript 编译器确切的索引类型


通过以上方法,你可以解决 "类型为 'number' 的表达式不能用于索引类型 '{ 1: number; 4: number; 5: number; 8: number; }'" 的错误。
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值