鍍金池/ 問答/PHP  網(wǎng)絡(luò)安全  HTML/ lazyload jquery |只要 scroll 到最下面,會不斷跟後端請

lazyload jquery |只要 scroll 到最下面,會不斷跟後端請求,但明明已經(jīng)沒有數(shù)據(jù)?

$(window).scroll(function(){
  var WindowHeight = $(window).height();

  if($(window).scrollTop() >= $(document).height() - WindowHeight){

    $('#loader').html('<img src="../images/loading_v2.svg">');

    var LastDiv = $(".data-display:last");
    var LastId  = $(".data-display:last").attr("id");
    var ValueToPass = "lastid="+LastId;

    $.ajax({
      type: "POST",
      url:"/module/user/order/lazyload.app",
      data: ValueToPass,
      cache: false,
      success: function(data){
        if(data != ''){
          LastDiv.after(data);
        }else{
          $('#loader').html('沒有更多。');
        }
      }
    });
  }
  return false;
});

好怪的現(xiàn)象,不知道哪裡寫錯了
只要 scroll 到最下面,會不斷跟後端請求,但明明已經(jīng)沒有數(shù)據(jù),必須要稍微往上 scroll 一點(diǎn),才會出現(xiàn) 沒有更多。
不然他就會一直出現(xiàn) 「<img src="../images/loading_v2.svg">」 loading 圖,然後消失,然後又出現(xiàn) loading 圖,又消失,不斷重複

回答
編輯回答
祈歡

...可能是滾動的太猛,scroll觸發(fā)多次,造成多次請求。設(shè)置個標(biāo)志位試試,每次請求前檢查標(biāo)志位,判斷是否正在請求,scroll加throttle函數(shù)。

2017年5月6日 09:55
編輯回答
近義詞

這段代碼本身并沒有判斷沒有數(shù)據(jù)的時候不再觸發(fā)加載., 像樓上說的可以加個標(biāo)志判斷.
比如在scroll最頂部加上:

if($('#loader').hasClass('nomore')) {
    return false;
}

在請求無數(shù)據(jù)時:

$('#loader').addClass('nomore').html('沒有更多。');

本身還需要加另一個標(biāo)志,是否在加載中.

2018年4月1日 10:09