首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在另一个axios请求中使用axios响应数据

在另一个axios请求中使用axios响应数据
EN

Stack Overflow用户
提问于 2020-09-24 16:30:51
回答 1查看 411关注 0票数 3

我正在使用axios获取信息,并且我需要在不同axios响应的另一个处理程序中获取该信息。我似乎无法在第二个响应处理中使用第一个响应中加载的数据。

例如:

代码语言:javascript
复制
const [firstData, setFirstData] = useState({});
const [secondData, setSecondData] = useState({});

await axios.get("url/firstRoute").then((response) => {
    setFirstData(response.data);
}).then(async () => {
    await axios.get("url/secondRoute").then((response) => {
        setSecondData(firstData); // firstData is still an empty Object here for some reason
    })
});

当我在第二个请求中时,如何确保firstData不为空?我还尝试使用firstData的useEffect钩子,并在其中调用第二个axios请求,但仍然得到firstData为空的相同结果。(假设两个请求都返回数据)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-24 16:50:17

您可以像这样从第一个.then返回值:

代码语言:javascript
复制
await axios
  .get('url/firstRoute')
  .then((response) => {
    setFirstData(response.data);
    return response.data;
  })
  .then(async (firstData) => {
    await axios.get('url/secondRoute').then((response) => {
      setSecondData(firstData); // firstData is still an empty Object here for some reason
    });
  });

在您的代码中,您正在设置state,但在then子句之前没有这样做。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64042481

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档