国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

jQuery實現瀑布流布局

2024-05-06 16:11:56
字體:
來源:轉載
供稿:網友
上篇文章我們介紹了使用原生的javascript實現了圖片瀑布流效果,本文我們來用jQuery來實現同樣的效果。
 
 

HTML

 

復制代碼代碼如下:

 <div id="main">
         <div class="box">
             <div class="pic">
                 <img src="images/0.jpg" style="border-left-color: rgb(0, 153, 204); border-left-width: 1px; border-left-style: solid; padding: 0px 3px; margin: 3px auto 0px; width: 640px; background-color: rgb(242, 246, 251); clear: both; border-top-color: rgb(0, 153, 204); border-top-width: 1px; border-top-style: solid; border-right-color: rgb(0, 153, 204); border-right-width: 1px; border-right-style: solid;"> 復制代碼代碼如下:

 * {
     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

 

復制代碼代碼如下:

 $(window).on("load",function () {
     waterfall();
     var dataInt = { "data":[{"src":"7.jpg"},{"src":"8.jpg"},{"src":"9.jpg"},{"src":"6.jpg"}]}
     //模擬json數據;
     $(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();
         }
     })
 });
 //流式布局主函數;
 function waterfall () {
     var $boxs=$("#main>div");
     //獲取#main元素下的直接子元素div.box;
     //獲取每一列的寬度;
     var w=$boxs.eq(0).outerWidth();
     //outerWidth()獲取包含padding和border在內的寬度;
     //var w=$boxs.eq(0).width();
     //width()只能獲取給元素定義的寬度;
     var cols=Math.floor($(window).width()/w);
     //獲取多少列;
     $("#main").width(w*cols).css("margin","0 auto");
     //設置#main元素的寬度和居中樣式;
     var hArr=[];
     //每一列高度的集合;
     $boxs.each(function (index,value) {
     //遍歷每一個box元素;
     //為了找到之前所有元素的最低點,然后將本元素設置到最低點之下;
         var h=$boxs.eq(index).outerHeight();
         //每一個box元素的高,
         if (index<cols) {
             hArr[index]=h;
             //確定每列第一個元素的高度;
         } else{
             var minH=Math.min.apply(null,hArr);
             //得出列高數組中的最小高度;
             var minHIndex=$.inArray(minH,hArr);
             //$.inArray()方法得出元素(minH)在數組(hArr)中的index值;
             //console.log(value);
             //此時的value是第一行之后的所有的box元素的DOM對象!;
             $(value).css({
             //$(value):將DOM對象轉換成jQuery對象,才能繼續使用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;
 }

 

詳細解釋清仔細參考注釋吧,我就不單獨再拉出來寫了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 八宿县| 宁阳县| 华容县| 漠河县| 黔南| 冕宁县| 宿松县| 安阳市| 漳浦县| 怀仁县| 澎湖县| 刚察县| 治县。| 大荔县| 台前县| 静海县| 田林县| 巴林左旗| 贵阳市| 崇文区| 泌阳县| 博湖县| 抚远县| 丹棱县| 河北省| 阿拉善右旗| 麟游县| 满洲里市| 广元市| 祥云县| 福贡县| 南华县| 巴南区| 荔浦县| 望城县| 察哈| 塔河县| 玛沁县| 无极县| 松原市| 孝昌县|