一、问题
在处理接口返回的数据,赋值给store中的数组时,报类型错误
data:{
cateList: []
}
const getCateList = async () => {
const res = await fetchCateList() as any
if ( == 200) {
=
}
}
二、原因
res已经定义了any类型,但是cateList的类型还没有定义,默认为never
三、解决
1、方式一 (TS断言 尖括号语法)
data: {
cateList: <any>[]
},
2、方式二 (TS断言 as语法)
data: {
cateList: [] as any
},
3、方式三 (TS接口 interface)
//接口返回的数据结构如下
= [
{id:'1',name:'xxx',level:1},
{id:'2',name:'xxx',level:2},
{id:'3',name:'xxx',level:3}
]
//根据返回的数据结构定义对应的类型
interface ICateList {
id: string
name: string
level:number
}
data: {
cateList: [] as ICateList[],
},
参考:/yangyukeke/p/