lazyload + ajax 沒有數據的時候的顯示,無效?

发布于 2022-09-07 23:35:07 字数 1910 浏览 25 评论 0

var $isFetchingNotes = false;

  $(window).scroll(function(){
    if($('#loader-blog').hasClass('nomore')) {
      return false;
    }

    var $scroll = $(window).scrollTop();
    var $docHeight = $(document).height();
    var $winHeight = $(window).height();

    if($scroll === $docHeight - $winHeight){

      if(!$isFetchingNotes) {

        $isFetchingNotes = true;

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

        var lastDiv = $('.data-display-blog:last');
        var lastId  = $('.data-display-blog:last').attr('id');
        var type  = $('.data-display-blog:last').attr('data-type');
        var query  = $('.data-display-blog:last').attr('data-query');
        var dataTo = 'lastid='+lastId+'&type='+type+'&query='+query;

        $.ajax({
          type: 'POST',
          url:'app',
          data: dataTo,
          cache: false,
          success: function(data){
            if(data != ''){
              lastDiv.after(data);
            }else{
              $('#loader-blog').addClass('nomore').html('nodata');
            }
          },
          complete: function () {
            $isFetchingNotes = false;
          }
        });

      }
    }
  });

我發現 scroll 滑到底的時候,即使後端數據是
他也不會執行 $('#loader-blog').addClass('nomore').html('nodata'); 這段?
我在裡面有加了 : alert事件,但是都遲遲沒有反應。
但我用谷歌 inspect 檢查 <div id="#loader-blog"></div> 每次滑下去都是有觸發東西的,會閃一下。(後來發現可能是觸發$('#loader-blog').html('<img src="../images/loading_v2.svg">');
怎麼會這樣呢?我確定後端給的值是空值...

我即使變成這樣:

if(data != ''){
              lastDiv.after(data);
            }else if(data == ''){
              $('#loader-blog').addClass('nomore').html('no-data');
            }

卻還是沒有反應。。。

補充:

我要如何在還沒有滾到最下面碰底的時候,就開始發出ajax請求?

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

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

发布评论

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

评论(3

恰似旧人归 2022-09-14 23:35:07

代码目测没有问题~,能否把后端返回的数据贴出来看看,或者添加如下代码在测试下:

// 控制台查看后端返回的数据
console.log(data);
if(data != ''){
    console.log("获取到新数据");
    lastDiv.after(data);
}else{
    console.log("没有更多数据了");
    $('#loader-blog').addClass('nomore').html('nodata');
}

看下控制台结果~,如果还不能定位到错误的话,建议把控制台信息贴出来

野稚 2022-09-14 23:35:07

complete: 请求完成后回调函数 (请求成功或失败之后均调用), 你应该在success中 当 data==='' 时,设置 $isFetchingNotes = false; 。问题应该出在这里。

九公里浅绿 2022-09-14 23:35:07

目前来看,代码里有两个疑似的问题:

  1. HTTP动词选择的是POST,但在数据上却用了GET拼接的方式。保险起见建议还是写成对象而不是字符串拼接。另外这里也可以在网络面板里看下返回的状态码是正常的200还是别的
  2. scroll是个高频事件,代码里可以看到是基于标志位做的防抖,但我觉得还是把复位放到success回调最后会更好吧,或者也可以用jQ的链式写法,用$.ajax().done().done()的形式,原success内容放在第一个done回调里,标志位复位放到第二个done回调里
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文