首頁  >  文章  >  web前端  >  jQuery 瀑布流 浮動佈局(一)(延遲AJAX載入圖片)

jQuery 瀑布流 浮動佈局(一)(延遲AJAX載入圖片)

高洛峰
高洛峰原創
2017-01-03 10:31:511151瀏覽

浮動佈局:即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=&#39;&#39;><img src=&#39;" + value1 + "&#39; alt=&#39;&#39; /><p>11111</p></a></li>") 
$("ul").eq(keysrc1).append(imgLi); 
}) 
}) 
onOff = true; 
}) 
}) 
} 
}); 
}) 
})

三、注意事項 
  當在執行AJAX請求的時候,是有資料在傳輸,所以需要一定的時間,才能取得回傳的jSON資料。 (有了數據,才能向UL中插入LI)而這個時候,如果用戶又一次拖動滾動條,那麼上面代碼的isSee 還是返回true;所以又會執行AJAX請求。這裡我們就需要手動設定一個“開關”,來控制。
  只有當資料載入完成後,並且都加進了對應的UL之後,再次拖曳時,打開這個“開關”,即onOff設為true;, 
  因為資料載入完成後,意味著每列的UL裡面,在最後面又多出了剛透過AJAX加入進來的LI數據,所以可以有再次的AJAX請求。 

更多jQuery 瀑布流 浮動佈局(一)(延遲AJAX載入圖片)相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn