今天在写ts
文件的过程中,我遍历了一个对象,然后取值的时候发现爆红,如下图👇
经过我一通排查(原因我对ts也不是很熟练),了解到大致意思是说key
的值类型不是string
类型,在javascript
中是默认给你转好的,而在Typescript
中则不是,因此要么转,要么声明,要么忽略…
- 方案一:忽略
在tsconfig.json
中compilerOptions
里面新增忽略的代码,就不会报错了,如下
"suppressImplicitAnyIndexErrors": true
- 方案二:声明
在定义的Interface
里对其进行声明,如下所示:
interface IComponent {
[key:string]: any
}
const allGloablComponent:IComponent = {SvgIcon,Pagination};
或者可以直接省略interface
,const
后面定义类型也OK
- 方案三:对其使用
keyof
进行判断
之前这样的,爆红:
allGloablComponent[key]
修复之后这样写:
allGloablComponent[key as keyof typeof allGloablComponent]
已经不报错啦!!!
个人推荐方案二和方案三,方案一有点any
的味道,意义不大,不推荐!