Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
4.1k views
in Technique[技术] by (71.8m points)

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

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

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

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

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

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

1.4m articles

1.4m replys

5 comments

57.0k users

...