简体   繁体   English

如何使用 axios 响应数据设置 state

[英]how to set state using axios response data

I am having issues with setting state. When I try to set the state of setDataTemp() from axios the data sent into setDataTemp is blank.我在设置 state 时遇到问题。当我尝试从 axios 设置 setDataTemp() 的 state 时,发送到 setDataTemp 的数据为空白。 however if I just console log the data directly I get response.但是,如果我只是直接控制台记录数据,我会得到响应。 Not sure what wrong不确定出了什么问题

setDataTemp is not empty setDataTemp 不为空

const [dataTemp, setDataTemp] = useState([]);

const _overlayFilder = async () => {
 let source = axios.CancelToken.source();

    await axios
      .get(network + '/getOverlayList', {
        cancelToken: source.token,
      })
      .then(response => {
        removeRootUUID(response.data.items, response.data.items);
        // console.log(response.data);
        return response.data;
      })
      .then(response => {
        setDataTemp(response.items);
      })
      .catch(function (e) {
        if (axios.isCancel(e)) {
          console.log(`request cancelled:${e.message}`);
        } else {
          console.log('another error happened:' + e.message);
        }
      })
      .finally(() => {
        console.log(dataTemp)
      });

If I don't set the state setDataTemp and I just console.log instead I prints the data如果我不设置 state setDataTemp 而我只是 console.log 而不是打印数据

const [dataTemp, setDataTemp] = useState([]);

const _overlayFilder = async () => {
 let source = axios.CancelToken.source();

    await axios
      .get(network + '/getOverlayList', {
        cancelToken: source.token,
      })
      .then(response => {
        removeRootUUID(response.data.items, response.data.items);
        // console.log(response.data);
        return response.data;
      })
      .then(response => {
        // the data that I want to set into setDataTemp
        console.log(response.items);
      })
      .catch(function (e) {
        if (axios.isCancel(e)) {
          console.log(`request cancelled:${e.message}`);
        } else {
          console.log('another error happened:' + e.message);
        }
      })
      

You are mixing an async function handling using a Promise-like approach with your axios call.您正在使用类似 Promise 的方法将async函数处理与axios调用混合axios
Try to change your code like this:尝试像这样更改您的代码:

const [dataTemp, setDataTemp] = useState([]);

const _overlayFilder = async () => {
  try {
    let source = axios.CancelToken.source();

    const { data } = await axios.get(network + '/getOverlayList', {
      cancelToken: source.token,
    });
    removeRootUUID(data.items, data.items);
    setDataTemp(data.items);

    console.log(dataTemp);
  } catch (err) {
    if (axios.isCancel(err)) {
      console.log(`request cancelled:${e.message}`);
    } else {
      console.log('another error happened:' + e.message);
    }
  }
};

You need to use useEffect :您需要使用useEffect

import { useEffect } from "react";

const [loading, setLoading] = useState(true);
const [dataTemp, setDataTemp] = useState([]);

const _overlayFilder = async () => {
    let source = axios.CancelToken.source();

    await axios
      .get(network + '/getOverlayList', {
        cancelToken: source.token,
      })
      .then(response => {
        removeRootUUID(response.data.items, response.data.items);
        // console.log(response.data);
        return response.data;
      })
      .then(response => {
        setDataTemp(response.items);
        setLoading(false);
      })
      .catch(function (e) {
        if (axios.isCancel(e)) {
          console.log(`request cancelled:${e.message}`);
        } else {
          console.log('another error happened:' + e.message);
        }
      })
      .finally(() => {
        console.log(dataTemp)
      });
}

//if triggered by onClick handler
useEffect(() => {
     
}, [loading, JSON.stringify(dataTemp)])

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM