请求的数据放在数组里面,在外面打印不到

臭臭?
  • 4
新手上路,请多包涵
 try {
  let DirBuckets=[]
  taskPhotoJsonPath.forEach((item: any) => {
    axios
      .get(`file://${item}`)
      .then((res: any) => {
        console.log(res);
        try {
          const { point, defect, packet } = res;
          if (packet) {
         //   resolve(packet[0])
            DirBuckets.push(packet[0])
          }
        } catch (e) {
          console.error(e);
          Modal.error({ content: "本地文件损坏,请重新同步服务器数据" });
        }
      })
      .catch(() => {
      });
  });
  console.log(DirBuckets, '当前读取的数据')
  setCurrentTask(currentTask);
}
 catch (error) {
  console.log(error);
}
回复
阅读 282
1 个回答

请求时异步的,你同步打印的时候当然是个空数组。改成这样试试:

 try {
  let DirBuckets=[]
  Promise.all(taskPhotoJsonPath.map((item: any) => {
    return axios
      .get(`file://${item}`)
      .then((res: any) => {
        console.log(res);
        try {
          const { point, defect, packet } = res;
          if (packet) {
         //   resolve(packet[0])
            DirBuckets.push(packet[0])
          }
        } catch (e) {
          console.error(e);
          Modal.error({ content: "本地文件损坏,请重新同步服务器数据" });
        }
      })
      .catch(() => {
      });      
  })).then(() => {
    console.log(DirBuckets, '当前读取的数据')
  })
}
 catch (error) {
  console.log(error);
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
你知道吗?

宣传栏