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

发布于 2022-09-07 22:04:10 字数 887 浏览 21 评论 0

$(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;
});

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

云朵有点甜 2022-09-14 22:04:11

这段代码本身并没有判断没有数据的时候不再触发加载., 像楼上说的可以加个标志判断.
比如在scroll最顶部加上:

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

在请求无数据时:

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

本身还需要加另一个标志,是否在加载中.

策马西风 2022-09-14 22:04:11

...可能是滚动的太猛,scroll触发多次,造成多次请求。设置个标志位试试,每次请求前检查标志位,判断是否正在请求,scroll加throttle函数。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文