好的,下面的代码“有效”,因为当您滚动到页面底部时,会触发 AJAX 函数并将结果附加到页面上的 #postswrapper div 中。
问题是:如果我在到达页面底部时滚动得非常快,AJAX 会触发几次并将几组结果加载到#postswrapper div 中(额外的“不需要”结果的数量取决于额外滚动的次数通过快速滚动触发事件)。
最终,每次用户到达底部时,我只需要提供一组结果。我试过添加计时器等,但无济于事。它显然将额外的滚动动作存储在 DOM 中,然后按顺序触发它们。
有任何想法吗?
如果对任何人有帮助,我正在使用 jquery.1.4.4.js。无论如何,在这种情况下, e.preventDefault() 不起作用。
$(window).scroll(function(e) {
e.preventDefault();
if ($(window).scrollTop() >= ($(document).height() - $(window).height())) {
$('div#loadmoreajaxloader').show();
$.ajax({
cache: false,
url: 'loadmore.php?lastid=' + $('.postitem:last').attr('id'),
success: function(html) {
if (html) {
$('#postswrapper').append(html);
$('div#loadmoreajaxloader').hide();
} else {
$('div#loadmoreajaxloader').html();
}
}
});
}
});