0

我正在尝试设置一个显示更多按钮来启动无限滚动。单击按钮后,它应该无限滚动直到结束。

function infiniteScroll() {

    var postHolder = document.getElementById('postHolder');
    var articleCount = postHolder.getElementsByTagName('article').length + 1;

    $.ajax({
        url: "/handlers/InfiniteScroll.ashx?page=" + articleCount + "",
        contentType: "text/html; charset=utf-8",
        dataType: "html",
        success: function (data) {
            if (data != "") {
                $('.posts-holder .article:last').after(data);
            }
        }
    });
 };

$("#showMore").click(function () {
     infiniteScroll();
     $(window).scroll(function () {
         var wintop = $(window).scrollTop(), docheight = $(document).height(), winheight = $(window).height();
         var scrolltrigger = 0.95;

         if (((wintop / (docheight - winheight)) > scrolltrigger) && test == 1) {
             infiniteScroll();
         }
     });
    $('#showMore').hide();
 });

但是由于某些原因,这段代码的 ajax 成功函数被调用了两次,结果被附加了两次。我做错了什么还是有更好的方法来设置它?

4

1 回答 1

0

我想通了,它是 var scrolltrigger = 0.95; 关于高度的某些东西导致它运行了两次。

于 2013-06-10T21:28:04.683 回答