jQuery實(shí)現(xiàn)瀑布流布局
更新時(shí)間:2014年12月12日 14:50:50 投稿:hebedich
上篇文章我們介紹了使用原生的javascript實(shí)現(xiàn)了圖片瀑布流效果,本文我們來用jQuery來實(shí)現(xiàn)同樣的效果。
HTML
復(fù)制代碼 代碼如下:
<div id="main">
<div class="box">
<div class="pic">
<img src="images/0.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="images/1.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="images/2.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="images/3.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="images/4.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="images/2.jpg" alt="">
</div>
</div>
</div>
CSS
復(fù)制代碼 代碼如下:
* {
margin: 0;
padding: 0;
}
#main {
position: relative;
}
.box {
padding:15px 0 0 15px;
float:left;
}
.pic {
padding: 10px;
border: 1px solid #ccc;
border-radius: 5px;
box-shadow: 0px 0px 5px #ccc;
img {
width:165px;
height:auto;
}
}
JavaScript
復(fù)制代碼 代碼如下:
$(window).on("load",function () {
waterfall();
var dataInt = { "data":[{"src":"7.jpg"},{"src":"8.jpg"},{"src":"9.jpg"},{"src":"6.jpg"}]}
//模擬json數(shù)據(jù);
$(window).on("scroll",function () {
if(checkScrollSlide){
$.each(dataInt.data,function (key,value) {
var oBox=$("<div>").addClass("box").appendTo($("#main"));
//jQuery支持連綴,隱式迭代;
var oPic=$("<div>").addClass('pic').appendTo($(oBox));
$("<img>").attr("src","images/"+$(value).attr("src")).appendTo(oPic);
});
waterfall();
}
})
});
//流式布局主函數(shù);
function waterfall () {
var $boxs=$("#main>div");
//獲取#main元素下的直接子元素div.box;
//獲取每一列的寬度;
var w=$boxs.eq(0).outerWidth();
//outerWidth()獲取包含padding和border在內(nèi)的寬度;
//var w=$boxs.eq(0).width();
//width()只能獲取給元素定義的寬度;
var cols=Math.floor($(window).width()/w);
//獲取多少列;
$("#main").width(w*cols).css("margin","0 auto");
//設(shè)置#main元素的寬度和居中樣式;
var hArr=[];
//每一列高度的集合;
$boxs.each(function (index,value) {
//遍歷每一個(gè)box元素;
//為了找到之前所有元素的最低點(diǎn),然后將本元素設(shè)置到最低點(diǎn)之下;
var h=$boxs.eq(index).outerHeight();
//每一個(gè)box元素的高,
if (index<cols) {
hArr[index]=h;
//確定每列第一個(gè)元素的高度;
} else{
var minH=Math.min.apply(null,hArr);
//得出列高數(shù)組中的最小高度;
var minHIndex=$.inArray(minH,hArr);
//$.inArray()方法得出元素(minH)在數(shù)組(hArr)中的index值;
//console.log(value);
//此時(shí)的value是第一行之后的所有的box元素的DOM對(duì)象!;
$(value).css({
//$(value):將DOM對(duì)象轉(zhuǎn)換成jQuery對(duì)象,才能繼續(xù)使用jQuery方法;
"position":"absolute",
"top":minH+"px",
"left":minHIndex*w+"px"
});
hArr[minHIndex]+=$boxs.eq(index).outerHeight();
//最低高元素的高度+剛添加到最低高度下的元素的高度=新的列高;
};
});
// console.log(hArr);
};
function checkScrollSlide () {
var $lastBox=$("#main>div").last();
var lastBoxDis=$lastBox.offset().top+Math.floor($lastBox.outerHeight()/2);
var scrollTop=$(window).scrollTop();
var documentH=$(window).height();
return (lastBoxDis<scrollTop+documentH)?true:false;
}
詳細(xì)解釋清仔細(xì)參考注釋吧,我就不單獨(dú)再拉出來寫了。
您可能感興趣的文章:
- jQuery Masonry瀑布流布局神器使用詳解
- jquery實(shí)現(xiàn)簡單的瀑布流布局
- 網(wǎng)頁瀑布流布局jQuery實(shí)現(xiàn)代碼
- 基于jquery實(shí)現(xiàn)瀑布流布局
- jQuery實(shí)現(xiàn)瀑布流布局詳解(PC和移動(dòng)端)
- jQuery+HTML5美女瀑布流布局實(shí)現(xiàn)方法
- Jquery實(shí)現(xiàn)瀑布流布局(備有詳細(xì)注釋)
- jQuery 瀑布流 絕對(duì)定位布局(二)(延遲AJAX加載圖片)
- jQuery 瀑布流 浮動(dòng)布局(一)(延遲AJAX加載圖片)
- JQuery實(shí)現(xiàn)簡單瀑布流布局
相關(guān)文章
jQuery利用cookie 實(shí)現(xiàn)本地收藏功能(不重復(fù)無需多次命名)
cookie 是存儲(chǔ)于訪問者計(jì)算機(jī)中的變量。這篇文章主要介紹了jQuery利用cookie 實(shí)現(xiàn)本地收藏功能不重復(fù)無需多次命名,需要的朋友可以參考下2019-11-11
jQuery回車實(shí)現(xiàn)登錄簡單實(shí)現(xiàn)
實(shí)現(xiàn)登錄的方法有很多,這里為大家介紹下實(shí)現(xiàn)回車提交表單,具體如下,感興趣的朋友可以參考下2013-08-08
探討JQUERY JSON的反序列化類 using問題的解決方法
本篇文章是對(duì)JQUERY JSON的反序列化類 using問題的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12
jquery動(dòng)態(tài)添加刪除一行數(shù)據(jù)示例
這篇文章主要介紹了jquery如何動(dòng)態(tài)添加刪除一行數(shù)據(jù),需要的朋友可以參考下2014-06-06
jQuery中scrollLeft()方法用法實(shí)例
這篇文章主要介紹了jQuery中scrollLeft()方法用法,實(shí)例分析了scrollLeft()方法的功能、定義及獲取或設(shè)置匹配元素相對(duì)滾動(dòng)條左側(cè)的偏移(offset)量時(shí)的使用技巧,需要的朋友可以參考下2015-01-01
基于jquery實(shí)現(xiàn)可定制的web在線富文本編輯器附源碼下載
UEditor的功能非常強(qiáng)大,官方已配備了php,asp,asp.net,java等語言的上傳程序,拿來就可以使用,當(dāng)然ueditor更具有功能插件接口,很輕松地添加自己定義功能到編輯器中,方便項(xiàng)目的不同需求2015-11-11
jQuery實(shí)現(xiàn)動(dòng)態(tài)添加節(jié)點(diǎn)與遍歷節(jié)點(diǎn)功能示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)添加節(jié)點(diǎn)與遍歷節(jié)點(diǎn)功能,結(jié)合實(shí)例形式分析了jQuery針對(duì)頁面元素節(jié)點(diǎn)元素的動(dòng)態(tài)添加與遍歷相關(guān)操作技巧,需要的朋友可以參考下2017-11-11

