91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ajax如何實時刷新處理

發布時間:2020-12-11 09:57:18 來源:億速云 閱讀:278 作者:小新 欄目:web開發

小編給大家分享一下ajax如何實時刷新處理,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

前端渲染頁面拿數據,無非就是ajax、socket,其他的暫時沒有用過,但項目還是使用ajax比較多。

下面來看一下一個簡單基于ajax短輪詢的請求

function req() {
    $.ajax({
        type: 'get',
        url: 'demo.php',
        dataType: 'json',
        success: function(res) {
            console.log(res);
        },
        error: function() {
            console.log('請求失敗~');
        }
    });
}
req();
setInterval(req, 3000);

如果網速快而穩定的話,可以這樣使用,但網速誰能確定呢,如果網速不穩定的話,請求一個接口需要5~10秒,這樣就會造成ajax請求堆積,近而引發不可估量的問題,那么怎樣去避免這個問題呢?

方式一:給請求賦上一個變量,然后每次輪詢先abort掉上一個請求

var ajaxReq = null;
function req(isLoading) {
    if(ajaxReq !== null) {
        ajaxReq.abort();
        ajaxReq = null;
    }
    ajaxReq = $.ajax({
        type: 'get',
        url: 'demo.php',
        dataType: 'json',
        beforeSend: function() {
            if(isLoading) {
                $('.zh-loading').show();
            }
        },
        success: function(res) {
            console.log(res);
        },
        complete: function() {
            if(isLoading) {
                $('.zh-loading').hide();
            }
        },
        error: function() {
            console.log('請求失敗~');
        }
    });
}
req(true);
setInterval(function() {
    req(false);
}, 3000);

猛一看,感覺還行,差不多就OK了,但作為前端的我們要不斷的去尋找更合適的方式,所以有個下面這個。

方式二:每一次輪詢都判斷上一次請求是否完成,完成了才會執行下一次的請求(推薦)

var isLoaded = false;
function req(opts) {
    $.ajax({
        type: 'get',
        url: 'demo.php',
        dataType: 'json',
        beforeSend: function() {
            if(opts.init === 1) {
                $('.zh-loading').show();
            }
            isLoaded = false;
        },
        success: function(res) {
            console.log(res);
        },
        complete: function() {
            if(opts.init === 1) {
                $('.zh-loading').hide();
            }
            isLoaded = true;
        },
        error: function() {
            console.log('請求失敗~');
        }
    });
}
req({"init": 1});
setInterval(function() {
    isLoaded && req({"init": 0});
}, 3000);

上面的 isLoaded && req({"init": 0}); 表示前面一個條件正確,則執行&&后面的方法

正常的寫法是

if(isLoaded) req({"init": 0});

另外注意一點:isLoaded=true 要在complete里加,如果只在success里加的話, 請求失敗了就不會輪詢再請求了。complete不管success或error都會執行

代碼就到這里了,thank you for attention~

以上是“ajax如何實時刷新處理”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

富锦市| 威信县| 余庆县| 富蕴县| 外汇| 平凉市| 图木舒克市| 额尔古纳市| 泸州市| 瓦房店市| 浠水县| 鹿泉市| 繁峙县| 临沂市| 枣庄市| 万载县| 六安市| 许昌县| 漳浦县| 宁国市| 芷江| 东兰县| 临桂县| 偃师市| 五常市| 夏河县| 绵竹市| 长子县| 洪雅县| 论坛| 东莞市| 晋城| 平邑县| 六枝特区| 辉南县| 龙山县| 左云县| 盐城市| 仁怀市| 筠连县| 华坪县|