- 时间:2020-09-27 14:45 编辑: 来源: 阅读:
- 扫一扫,手机访问
摘要:jQuery 瀑布流 浮动布局(一)(延迟AJAX加载图片)
浮动布局:即HTML结构的列,是用浮动方式。
[b]一、功能分析:[/b]
1.判断图片是否进入可视区域;
2.用AJAX请求服务器数据;
3.将数据播入到相应的列队;
[b]二、实现方法:[/b]
给window的scroll事件l绑定一个处理函数:做如下工作:
1.如何判断最后一行的图片,是否进入了可视区域?
如果:最后一行的某个图片距离浏览器可视区域顶部的距离值 小于 (可视区域的高度+滚动条滑动的距离值);
那么:就可以判定这个图片进入了浏览器的可视区域;
2.如何用AJAX请求服务器数据;
$.getJSON()方法,直接请求JSON格式的数据;
3.将数据播入到相应的列队;
使用$.each循环,将对应的JSON数据入到对应的列当中
[url=]$("ul").eq(keysrc1).append(imgLi);
})
})
onOff = true;
})
})
}
});
})
})
[b]三、注意事项[/b]
当在执行AJAX请求的时候,是有数据在传输,所以需要一定的时间,才能获得返回的jSON数据。(有了数据,才能向UL中插入LI)而这个时候,如果用户又一次拖动滚动条,那么上面代码的isSee 还是返回true;所以又会执行AJAX请求。这里我们就需要手动设置一个“开关”,来控制。
只有当数据加载完成后,并且都添加进了对应的UL之后,再次拖动时,打开这个“开关”,即onOff设为true;,
因为数据加载完成后,意味着每列的UL里面,在最后面又多出了刚通过AJAX添加进来的LI数据,所以可以有再次的AJAX请求。
DEMO下载[/url](这个要在本地机器上安装服务器平台。我用的是PHP套装APPSERV,里面的是APACHE)