javascript - 页面滚到底部自动加载加载出现请求多次bug
PHP中文网
PHP中文网 2017-04-11 12:00:37
[JavaScript讨论组]

代码如下:

$(window).scroll(function(){
    var scrolltop=$(window).scrollTop();
    var wheight=$(window).height();
    var dheight=$(document).height();
    if(scrolltop>dheight-wheight-20){
        page++;
        $.ajax({
            type: "GET",
            url: url+"page/"+page,
            dataType: "json",
            success: function(data){
                $("#list").append(html字符串);
            }
    }
})

发现chrome开发者工具里显示发送多次请求,

求解决方案!

PHP中文网
PHP中文网

认证0级讲师

全部回复(2)
大家讲道理
//    增加一个变量记录是否处于请求中
var flag = true;

$(window).scroll(function(){
    var scrolltop=$(window).scrollTop();
    var wheight=$(window).height();
    var dheight=$(document).height();
    if(scrolltop>dheight-wheight-20 && flag){
        //    开始请求的时候,将状态置false;
        //    这样就算高度达到请求标准也无法进入请求状态
        flag = false;
        page++;
        $.ajax({
            type: "GET",
            url: url+"page/"+page,
            dataType: "json",
            success: function(data){
                $("#list").append(html字符串);
                //    将标志置为true,这样当高度再次达到标准时,可以执行请求
                flag = true;
            }
    }
})
巴扎黑
function performScroll(){
    var scrolltop=$(window).scrollTop();
    var wheight=$(window).height();
    var dheight=$(document).height();
    if(scrolltop>dheight-wheight-20){
        page++;
        $(window).unbind('scroll');
        $.ajax({
            type: "GET",
            url: url+"page/"+page,
            dataType: "json",
            success: function(data){
                $("#list").append(html字符串);
                $(window).bind('scroll',performScroll);
            }
    }
}
$(window).bind('scroll',performScroll);
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号