TS类型报错解决:元素隐式具有 “any“ 类型,因为类型为 “string“ 的表达式不能用于索引类型 “{}“。 在类型 “{}“ 上找不到具有类型为 “string“ 的参数的索引签名。

遍历对象,在没有专门定义的情况下,object中并没有string,即类型为 "string" 的表达式不能用于索引类型 "{}"

元素隐式具有 “any” 类型,因为类型为 “string” 的表达式不能用于索引类型 “{}”。 在类型 “{}” 上找不到具有类型为 “string” 的参数的索引签名。

解决方法:Record(string,unknow)。这样就定义了key是string。

如:一个去除对象中空值的方法。

export const deleteEmpty = (obj: Record<string, unknown>): Record<string, unknown> => {
  const resObj: Record<string, unknown> = {}
  const arr: Array<string> = Object.keys(obj)
  arr.forEach((key) => {
    if (!isEmpty(obj[key])) {
      resObj[key] = obj[key]
    }
  })
  return resObj
}

其他

参考了Ts中string、number和any等类型 不能当做索引用,怎么处理? - 掘金 (juejin.cn),解决方法为:把key变为key as keyof typeof object,这就要求每次出现key的时候都要使用key as keyof typeof object,重复性太高。

后来定义了一个interface

interface MyObject {
	[key: string]: unknown;
}
const deleteEmpty = (obj: MyObject): object => {
	const resObj = {};
	Object.keys(obj).forEach((key) => {
		if (!isEmpty(obj[key])) {
			resObj[key] = obj[key];
		}
	});
	return resObj;
};

这样也不会报错,但是没必要定义一个新类型。可以用Record(string,unknow)代替。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 元素隐式具有 "any" 类型,是因为在 TypeScript 中,如果一个对象没有明确指定类型,那么它的类型就是 "any"。在这种情况下,如果我们尝试使用一个类型为 "string" 的表达式索引这个对象,TypeScript 就会报错,因为 "string" 类型不能用于索引类型。因此,为了避免这种错误,我们需要明确指定对象的类型,或者使用类型断言来告诉 TypeScript 我们知道这个对象的类型是什么。 ### 回答2: 在 TypeScript 中,元素隐式具有 "any" 类型,原因是因为如果我们声明数组时没有指定数组内元素类型,TypeScript 就无法确定数组内元素类型。 例如,如果我们声明了一个空数组变量 arr,但是并没有在声明时指定 arr 变量的类型,那么 TypeScript 就不知道这个数组的元素类型是什么。 在使用元素时,如果我们尝试使用类型为 "string" 的表达式来做数组索引,就会出现问题,因为这样的表达式不能用作索引类型。 因此,为了避免这种情况,TypeScript 就将元素隐式指定为 "any" 类型,这样在使用元素时,就可以使用任何类型表达式来做索引,从而避免了出现类型错误的情况。 需要注意的是,虽然 TypeScript 将元素隐式指定为 "any" 类型,但是我们可以在声明数组时,显式指定数组内元素类型,这样就可以让 TypeScript 知道数组内元素的具体类型,从而更好地检查代码的类型安全性。 ### 回答3: 在 TypeScript 中,元素类型默认是 "any" 类型。这意味着我们可以将任何类型的值添加到数组或对象中,而不需要对其类型进行任何限制。而索引类型是一种特殊的类型,在 TypeScript 中,它可以用于对象或数组的索引访问,例如 obj[key] 或者 arr[index]。 如果我们尝试对一个 "string" 类型表达式进行索引访问,就会出现类型错误。因为 "string" 类型表达式不能用于索引类型,因此 TypeScript 编译器无法确定我们要访问对象或数组中的哪个元素,这也就导致了类型错误。 因此,元素类型应该被隐式指定为 "any" 类型,这样就可以将任何类型的值添加到数组或对象中,而不会出现类型错误。但是,在实际开发中,为了让代码更加可读和维护,我们应该尽量指定元素的具体类型,这能够减少代码错误,并且在之后的开发过程中能够更容易地维护和修改代码。 总结:元素隐式具有 "any" 类型,因为类型为 "string" 的表达式不能用于索引类型。在实际开发中,应该尽量指定元素的具体类型,以提高代码可读性、减少代码错误和更容易地维护和修改代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

karshey

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值