詳解axios超時的種種問題

一、axios超時沒效果

在網路請求中,經常會遇到請求超時這個問題。axios默認的超時時間為0,也就意味著請求沒有超時限制。但是在實際場景中,如果請求一直沒有響應,我們需要控制超時時間,以保證請求時間的合理性。然而,有時候我們會在代碼中設置timeout,但是請求卻沒有在規定的時間內超時,這是為什麼呢?

這種情況一般是因為後端沒有返迴響應,因此axios不能識別這個請求是否超時,因此我們需要使用cancelToken來取消請求,以避免此類問題的出現。

axios.get('/api', {
    cancelToken: new CancelToken(function (cancel) {
        setTimeout(() => {
            cancel('Timeout');
        }, 1000);
    })
}).then(response => {
    console.log(response);
}).catch(e => {
    console.log(e.message);
});

二、axios超時時間默認值

axios默認的超時時間為0,即沒有超時限制。如果我們需要設置超時時間,可以在請求配置中進行設置。超時時間可以是一個數字或者是一個對象。如果是數字,則表示超時時間的毫秒數。如果是對象,則可以分別設置請求超時時間、連接超時時間、響應超時時間。

axios.get('/api', { timeout: 5000 });
// 或者
axios.get('/api', {
    timeout: {
        request: 5000, // 請求超時時間
        connect: 5000, // 連接超時時間
        response: 5000, // 響應超時時間
    }
});

三、axios超時重試機制

在網路請求中,如果請求無響應或者響應較慢,我們可以使用axios的重試機制重新發送請求。我們可以設置重試次數和重試間隔,來控制網路請求的穩定性。

axios.get('/api', {
    timeout: 1000,
    retry: 3, // 重試次數
    retryDelay: 1000, // 重試間隔
}).then(response => {
    console.log(response);
}).catch(e => {
    console.log(e.message);
});

四、axios超時後做什麼工作

當axios超時後,我們可以採取多種處理方式。比如,可以重新發送請求,或者顯示錯誤信息。下面是一個示例:

axios.interceptors.response.use((response) => {
    return response;
}, (error) => {
    const { config, response } = error;
    if (response.status === 504) {
        const retry = config.retry || 0;
        const retryDelay = config.retryDelay || 1000;
        if (retry > 0) {
            return new Promise((resolve) => {
                setTimeout(() => {
                    console.log(`Retry: ${config.url}`);
                    config.retry--;
                    resolve(axios(config));
                }, retryDelay);
            });
        }
    }
    return Promise.reject(error);
});

在這個示例中,如果請求超時(狀態碼為504),則會根據重試次數和重試間隔重新發送請求。如果重試次數為0,則會直接顯示請求錯誤信息。

五、總結

在網路請求中,我們經常會遇到請求超時的問題。針對這個問題,axios提供了多種解決方案,包括使用cancelToken取消請求、設置超時時間、使用重試機制等等。希望本文可以幫助大家更好地理解axios超時的相關問題。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/183511.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-25 05:46
下一篇 2024-11-25 05:46

相關推薦

  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智慧等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • 如何解決WPS保存提示會導致宏不可用的問題

    如果您使用過WPS,可能會碰到在保存的時候提示「文件中含有宏,保存將導致宏不可用」的問題。這個問題是因為WPS在默認情況下不允許保存帶有宏的文件,為了解決這個問題,本篇文章將從多個…

    編程 2025-04-29
  • Java Thread.start() 執行幾次的相關問題

    Java多線程編程作為Java開發中的重要內容,自然會有很多相關問題。在本篇文章中,我們將以Java Thread.start() 執行幾次為中心,為您介紹這方面的問題及其解決方案…

    編程 2025-04-29
  • 使用axios獲取返回圖片

    使用axios獲取返回圖片是Web開發中很常見的需求。本文將介紹如何使用axios獲取返回圖片,並從多個方面進行詳細闡述。 一、安裝axios 使用axios獲取返回圖片前,首先需…

    編程 2025-04-29
  • Python爬蟲亂碼問題

    在網路爬蟲中,經常會遇到中文亂碼問題。雖然Python自帶了編碼轉換功能,但有時候會出現一些比較奇怪的情況。本文章將從多個方面對Python爬蟲亂碼問題進行詳細的闡述,並給出對應的…

    編程 2025-04-29
  • NodeJS 建立TCP連接出現粘包問題

    在TCP/IP協議中,由於TCP是面向位元組流的協議,發送方把需要傳輸的數據流按照MSS(Maximum Segment Size,最大報文段長度)來分割成若干個TCP分節,在接收端…

    編程 2025-04-29
  • 如何解決vuejs應用在nginx非根目錄下部署時訪問404的問題

    當我們使用Vue.js開發應用時,我們會發現將應用部署在nginx的非根目錄下時,訪問該應用時會出現404錯誤。這是因為Vue在刷新頁面或者直接訪問非根目錄的路由時,會認為伺服器上…

    編程 2025-04-29
  • 如何解決egalaxtouch設備未找到的問題

    egalaxtouch設備未找到問題通常出現在Windows或Linux操作系統上。如果你遇到了這個問題,不要慌張,下面我們從多個方面進行詳細闡述解決方案。 一、檢查硬體連接 首先…

    編程 2025-04-29
  • Python折扣問題解決方案

    Python的折扣問題是在計算購物車價值時常見的問題。在計算時,需要將原價和折扣價相加以得出最終的價值。本文將從多個方面介紹Python的折扣問題,並提供相應的解決方案。 一、Py…

    編程 2025-04-28
  • Python存款買房問題

    本文將會從多個方面介紹如何使用Python來解決存款買房問題。 一、計算存款年限和利率 在存款買房過程中,我們需要計算存款年限和存款利率。我們可以使用以下代碼來計算存款年限和利率:…

    編程 2025-04-28

發表回復

登錄後才能評論