繁体   English   中英

Axios cancelToken,使取消的请求静默失败

[英]Axios cancelToken, make cancelled request fail silently

我正在使用react-hook-form创建一个验证帐号 onChange 的输入表单

 useEffect(() => {
    if (account_number.length >= 6) {
      verifyAccountNumber();
    }
    return () => source.cancel('Request canceled!');
  }, [account_number, bank_code, verifyAccountNumber]);

verifyAccountNumber function 在account_numberbank_code state 更改时运行。

这是实际的 function

const verifyAccountNumber = useCallback(async () => {
    setAccountLoading(true);
    setAccountError({ status: false, serverError: false });
    try {
      const account = await restAPI.get(
        `/misc/verify-account/${account_number}/${bank_code}`,
        { cancelToken: token }
      );
      setAccount(account.data.data.data.account_name);
    } catch (err) {
      console.log(err);
      if (!axios.isCancel(err)) {
        setAccountError({
          status: true,
          serverError: err.response.data.serverError,
        });
      }
    }
    setAccountLoading(false);
  }, [account_number, bank_code]);

有没有办法防止 try catch 块将取消的请求作为错误捕获? 因为它弄乱了我的 UI/UX

如果你想防止捕获取消错误,你必须在你的情况下重新抛出它。

if (axios.isCancel(err)) { 
    throw err 
} else { 
    setAccountError(...) 
} 

(从评论中回答以记录此问题已解决)

暂无
暂无

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

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