关于前端:Ts中stringnumber和any等类型-不能当做索引用怎么处理

导文

Ts中string、number和any等类型 不能当做索引用,怎么解决?
报错:元素隐式具备“any”类型,因为类型为“number”的表达式不能用于索引类型“[***”。在类型“[ ***”上找不到具备类型为“number"的参数的索引签名。 ts(7053)
keyof 的应用

问题

Ts中string、number和any等类型 不能当做索引用,怎么解决?

const handerField = (item: number) => {
   caselist= data.showList[item]//报错
}

元素隐式地领有 any 类型,因为 number类型不能被用于索引 {} 类型。

解决办法

办法1

const handerField = (item: number) => {
   caselist= (data.showList as any)[item];
}

办法2

const handerField = (item: number) => {
   caselist= data.showList [item as keyof typeof data.showList ]
}

办法3

const handerField =  function <T extends object, K extends keyof T>(obj: T, key: K) {
  return obj[key];
}

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理