Javascript Typescript抱怨显式类型没有索引签名
Typescript正在引发错误Javascript Typescript抱怨显式类型没有索引签名,javascript,typescript,types,typescript-typings,Javascript,Typescript,Types,Typescript Typings,Typescript正在引发错误“元素隐式地具有'any'类型,因为类型'HumansToDogs'没有索引签名。”关于以下代码 对我来说,每件事似乎都是直截了当的,有人能帮我吗 type HumanName='Jessie'|'Mark'; 键入DogName='Spot'|'Buddy'; 类型:人狗={ [输入人名]:DogName;//这不是索引签名吗? } const humansToDogs:humansToDogs={ “杰西”:“伙计”, '标记':'点', }; for(人形狗
“元素隐式地具有'any'类型,因为类型'HumansToDogs'没有索引签名。”
关于以下代码
对我来说,每件事似乎都是直截了当的,有人能帮我吗
type HumanName='Jessie'|'Mark';
键入DogName='Spot'|'Buddy';
类型:人狗={
[输入人名]:DogName;//这不是索引签名吗?
}
const humansToDogs:humansToDogs={
“杰西”:“伙计”,
'标记':'点',
};
for(人形狗中的const human){
const dog=humansToDogs[human];//此处的索引签名错误
}
的..of的将循环变量键入字符串。使用noImplicitAny
时,您无法索引到具有任意字符串的类型。最简单的解决方案是使用类型断言:
for (const human in humansToDogs) {
const dog = humansToDogs[human as HumanName]; // Index signature error here
}
您可以显式地让Typescript编译器知道human
引用了HumanName
的键,如下所示:
humansToDogs[human as keyof HumanName]
但更好的方法是定义数据的形状,您可以显式定义一个将索引声明为字符串的新类型:
type HumanNames = {[k: string] HumanName};