vue3 + TS ts判断异步返回值问题?

image.png

编辑器提示 但是能正常用

阅读 738
3 个回答

TypeScript 是一门强类型语言,当你声明一个变量或参数时,编译器会自动推断它的类型。在上面的代码中,res 变量被初始化为一个空对象 {},因此编译器默认认为它是一个没有任何属性的空对象。
当你使用可选链 res?.status 时,编译器会检查这个属性是否存在于对象中,并给出相应的警告信息。
你可以尝试使用以下方法来解决提示报错 或者忽略
两种方式解决:
1

if ((res as { status?: number })?.status === 200) {
    console.log(res, 'res');
  }

2 定义一个接口类型,包含期望的属性及其类型

type resType = {
  status?: number;
  message?: string;
};

async function getUserInfolist() {// 
  let res:resType = await new Promise(function (reslove){
    reslove({status: 200,message: '成功'})
  })
  if(res?.status === 200){
    console.log(res,'res')
  }
}

这是因为 ts 使用 unknown 实例化了 Promise,你可以指定一个类型:

async function getInfo() {
  const res = await new Promise<{ status: number; message: string }>(resolve =>
    resolve({ status: 200, message: 'success' }),
  )

  if (res.status === 200) console.log(res)
}

image.png

你调接口的时候把request 也添加下类型就行

推荐问题
logo
Microsoft
子站问答
访问
宣传栏