浮動佈局:即HTML結構的列,是用浮動方式。
一、功能分析:
1.判斷圖片是否進入視覺區域;
2.用AJAX請求伺服器資料;
3.將資料播入對應的欄位給對應的列隊; window的scroll事件l綁定一個處理函數:做如下工作:
1.如何判斷最後一行的圖片,是否進入了可視區域?
如果:最後一行的某個圖片距離瀏覽器可視區域頂部的距離值小於(可視區域的高度+滾動條滑動的距離值);
那麼:就可以判定這個圖片進入了瀏覽器的可視化區域;
2.如何使用AJAX請求伺服器資料;
$.getJSON()方法,直接請求JSON格式的資料;
『 3.將資料播入對應的列隊;資料入到對應的列當中
$(function(){ //判断每个UL的最后一个LI,是否进入可视区域 function see(objLiLast){ //浏览器可视区域的高度 var see = document.documentElement.clientHeight; //滚动条滑动的距离 var winScroll = $(this).scrollTop(); //每个UL的最后一个LI,距离浏览器顶部的 var lastLisee = objLiLast.offset().top return lastLisee < (see+winScroll)?true:false; } //是否请求出AJAX的“开关”; var onOff = true; $(window).scroll(function(){ //拖动滚条时,是否发送AJAX的一个“开关” $("ul").each(function(index, element) { //引用当前的UL var ulThis = this; //引用最后一个LI var lastLi = $("li:last",this); //调用是否进入可视区域函数 var isSee = see(lastLi); if(isSee && onOff){ onOff = false; //发送AJAX请求,载入新的图片 $.getJSON("test1.js",function(data){ //对返回JSON里面的list数据遍历 $.each(data.list,function(keyList,ovalue){ //对LIST里面的SRC数组遍历,取到图片路径 $.each(ovalue,function(keySrc,avalue){ $.each(avalue,function(keysrc1,value1){ var imgLi = $("<li><a href=''><img src='" + value1 + "' alt='' /><p>11111</p></a></li>") $("ul").eq(keysrc1).append(imgLi); }) }) onOff = true; }) }) } }); }) })
更多jQuery 瀑布流 浮動佈局(一)(延遲AJAX載入圖片)相關文章請關注PHP中文網!