zoukankan      html  css  js  c++  java
  • 瀑布流布局--jQuery写法

    HTML

     1 <div id="main">
     2         <div class="box">
     3             <div class="pic">
     4                 <img src="images/0.jpg" alt="">
     5             </div>
     6         </div>
     7         <div class="box">
     8             <div class="pic">
     9                 <img src="images/1.jpg" alt="">
    10             </div>
    11         </div>
    12         <div class="box">
    13             <div class="pic">
    14                 <img src="images/2.jpg" alt="">
    15             </div>
    16         </div>
    17         <div class="box">
    18             <div class="pic">
    19                 <img src="images/3.jpg" alt="">
    20             </div>
    21         </div>
    22         <div class="box">
    23             <div class="pic">
    24                 <img src="images/4.jpg" alt="">
    25             </div>
    26         </div>
    27         <div class="box">
    28             <div class="pic">
    29                 <img src="images/2.jpg" alt="">
    30             </div>
    31         </div>
    32 </div>

    CSS

     1 * {
     2     margin: 0;
     3     padding: 0;
     4 }
     5 #main {
     6     position: relative;
     7 
     8 }
     9 .box {
    10     padding:15px 0 0 15px;
    11     float:left;
    12 }
    13 .pic {
    14     padding: 10px;
    15     border: 1px solid #ccc;
    16     border-radius: 5px;
    17     box-shadow: 0px 0px 5px #ccc;
    18     img {
    19         width:165px;
    20         height:auto;
    21     }
    22 }

    JavaScript

     1 $(window).on("load",function () {
     2     waterfall();
     3     var dataInt = { "data":[{"src":"7.jpg"},{"src":"8.jpg"},{"src":"9.jpg"},{"src":"6.jpg"}]}
     4     //模拟json数据;
     5     $(window).on("scroll",function () {
     6         if(checkScrollSlide){
     7             $.each(dataInt.data,function (key,value) {
     8                 var oBox=$("<div>").addClass("box").appendTo($("#main"));
     9                 //jQuery支持连缀,隐式迭代;
    10                 var oPic=$("<div>").addClass('pic').appendTo($(oBox));
    11                 $("<img>").attr("src","images/"+$(value).attr("src")).appendTo(oPic);
    12             });
    13             waterfall();
    14         }
    15     })
    16 });
    17 //流式布局主函数;
    18 function waterfall () {
    19     var $boxs=$("#main>div");
    20     //获取#main元素下的直接子元素div.box;
    21 
    22     //获取每一列的宽度;
    23     var w=$boxs.eq(0).outerWidth();
    24     //outerWidth()获取包含padding和border在内的宽度;
    25     //var w=$boxs.eq(0).width();
    26     //width()只能获取给元素定义的宽度;
    27 
    28     var cols=Math.floor($(window).width()/w);
    29     //获取多少列;
    30     $("#main").width(w*cols).css("margin","0 auto");
    31     //设置#main元素的宽度和居中样式;
    32 
    33     var hArr=[];
    34     //每一列高度的集合;
    35     $boxs.each(function (index,value) {
    36     //遍历每一个box元素;
    37     //为了找到之前所有元素的最低点,然后将本元素设置到最低点之下;
    38         var h=$boxs.eq(index).outerHeight();
    39         //每一个box元素的高,
    40         if (index<cols) {
    41             hArr[index]=h;
    42             //确定每列第一个元素的高度;
    43         } else{
    44             var minH=Math.min.apply(null,hArr);
    45             //得出列高数组中的最小高度;
    46             var minHIndex=$.inArray(minH,hArr);
    47             //$.inArray()方法得出元素(minH)在数组(hArr)中的index值;
    48             //console.log(value);
    49             //此时的value是第一行之后的所有的box元素的DOM对象!;
    50             $(value).css({
    51             //$(value):将DOM对象转换成jQuery对象,才能继续使用jQuery方法;
    52                 "position":"absolute",
    53                 "top":minH+"px",
    54                 "left":minHIndex*w+"px"
    55             });
    56             hArr[minHIndex]+=$boxs.eq(index).outerHeight();
    57             //最低高元素的高度+刚添加到最低高度下的元素的高度=新的列高;
    58         };
    59     });
    60     // console.log(hArr);
    61 };
    62 function checkScrollSlide () {
    63     var $lastBox=$("#main>div").last();
    64     var lastBoxDis=$lastBox.offset().top+Math.floor($lastBox.outerHeight()/2);
    65     var scrollTop=$(window).scrollTop();
    66     var documentH=$(window).height();
    67     return (lastBoxDis<scrollTop+documentH)?true:false;
    68 }
  • 相关阅读:
    【疯狂积累CSS】1:CSS基础
    阿里云服务器配置小程序用ssl证书
    阿里云服务器申请ssl安全证书
    PDO连接SQLServer2008(linux和windows)
    win7 PHP7.0的PDO扩展
    Apache+php+mysql win7 64位安装的几个注意事项
    PHP配置xdebug
    PHPExcel导出
    【设计模式】命令模式
    【maven学习笔记】 01 初见
  • 原文地址:https://www.cnblogs.com/yizihan/p/4158436.html
Copyright © 2011-2022 走看看