react查询 - 取消未决或以前的请求

IT技术 javascript reactjs axios react-query
2022-07-21 00:21:51

我正在尝试取消任何先前/待处理的请求,如果它们花费的时间太长并且用户导航到另一个组件,当前查询采用状态值,并且当它更改组件时重新呈现这很好并且期望的行为. 但是,在网络选项卡中查看请求仍处于待处理状态。有没有办法在react查询中取消任何以前的请求。我已经尝试根据文档取消查询,但它不正确,因为它没有取消。

  const [value, setValue] = React.useState<boolean>(false);

  const getData = async (value: number): Promise<any> => {
    const CancelToken = axios.CancelToken
    const source = CancelToken.source()
    const response = await axios.get(`https://xxxxxx?value=${value}`, {
        cancelToken: source.token,
    }).then(res => res.data);
    if (CancelToken) {
        response.cancel = () => {
            source.cancel('Query was cancelled by React Query')
        }
    }
    return response;
}

const { data: result, status, error, isFetching }: any = useQuery(['getData', value], () => getData(value),
    {
        refetchOnWindowFocus: false,
    }
);
2个回答

您不能附加.cancel到异步函数中的Promise,因为异步函数将始终返回一个新的 Promise,而无需附加您附加的取消函数。如果要附加取消函数,最好使用Promise链而不是异步函数。

更好的是,react-query 现在通过提供开箱即用的 AbortSignal 来支持取消,您只需要将其附加到您的请求中。

使用 axios 0.22+ 和 react-query v3.30+,您可以:

 const query = useQuery('key', ({ signal }) =>
   axios.get('/xxxx', {
     signal,
   })
 )

这样,react-query 将在查询未使用或您调用时取消查询的网络请求queryClient.cancelQueries('key'),例如当用户单击按钮时。

您需要根据 getData() 中的响应抛出错误。React-Query 将捕获该错误并触发 onError 事件。