ajax如何實時刷新處理-創新互聯

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

我們提供的服務有:成都做網站、網站制作、微信公眾號開發、網站優化、網站認證、潮陽ssl等。為上1000家企事業單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的潮陽網站制作公司

前端渲染頁面拿數據,無非就是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如何實時刷新處理”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!

新聞標題:ajax如何實時刷新處理-創新互聯
網頁路徑:http://m.kartarina.com/article14/diccde.html

成都網站建設公司_創新互聯,為您提供云服務器、手機網站建設、ChatGPT、移動網站建設、網站排名、用戶體驗

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

搜索引擎優化
主站蜘蛛池模板: 亚洲国产精品无码久久九九 | 久久国产精品无码HDAV | 亚洲午夜AV无码专区在线播放| 国产精品无码制服丝袜| 亚洲国产a∨无码中文777| 亚洲va成无码人在线观看| 无码免费又爽又高潮喷水的视频| 亚洲精品~无码抽插| 亚洲成a人片在线观看天堂无码| 国产亚洲精品无码拍拍拍色欲| 久久久久成人精品无码中文字幕| 日产无码1区2区在线观看| 日韩人妻无码中文字幕视频| 中文字幕无码久久久| 中文字幕久久久人妻无码| 免费人成无码大片在线观看| 中文无码伦av中文字幕| 国产成人无码A区在线观看导航| 男人的天堂无码动漫AV| 精品无码国产污污污免费网站国产| 91精品久久久久久无码 | 久久久久亚洲AV无码专区首JN| 亚洲精品国产日韩无码AV永久免费网 | 少妇人妻av无码专区| 亚洲av激情无码专区在线播放| 国产日韩AV免费无码一区二区| 免费A级毛片无码A∨男男| 国产莉萝无码AV在线播放| 精品深夜AV无码一区二区| 手机永久无码国产AV毛片| 久久午夜无码鲁丝片直播午夜精品| 亚洲无码日韩精品第一页| 国产精品无码不卡一区二区三区| 免费无码A片一区二三区| 18禁超污无遮挡无码免费网站国产| 亚洲Av无码国产一区二区| HEYZO无码中文字幕人妻| 国产精品无码AV不卡| 无码精品蜜桃一区二区三区WW| 国产精品无码v在线观看| 国产av永久无码天堂影院|