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

发布于 2022-09-12 13:39:40 字数 653 浏览 14 评论 0

 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);
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

风透绣罗衣 2022-09-19 13:39:40

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

 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);
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文