HTML

 <div id="main">
<div class="box">
<div class="pic">
<img src="data:images/0.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="data:images/1.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="data:images/2.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="data:images/3.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="data:images/4.jpg" alt="">
</div>
</div>
<div class="box">
<div class="pic">
<img src="data:images/2.jpg" alt="">
</div>
</div>
</div>

CSS

 * {
margin:;
padding:;
}
#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;
}

最新文章

  1. 二叉排序树(Binary Sort Tree)
  2. java 时间戳和PHP时间戳 的转换
  3. 如何在腾讯云快速构建一个Wordpress个人站点
  4. leetcode 149. Max Points on a Line --------- java
  5. java.io.EOFException java.io.ObjectInputStream$PeekInputStream.readFully 错误
  6. leetcode&mdash;triangle
  7. 学习java随笔第二篇:java开发工具——Eclipse
  8. linq 跨库查询
  9. 贪心-hdu-1789-Doing Homework again
  10. Csharp 高级编程 C7.1.2
  11. 为程序指定运行时所在的CPU核
  12. 专题合集:深入Android媒体存储服务
  13. 【水】HDU 2099——整除的尾数
  14. mustache.js 使用
  15. QQ浏览器等window.innerHeight首次读取的高度不正确的解决办法
  16. [ZJOI 2006]超级麻将
  17. 目前的.NET 主流的后端ORM框架
  18. linux基础之CentOS7新特性
  19. cocoapod podpackage 自动根据podfile生成framework实现二进制化,原创脚本,转载请注明出处
  20. VS解决-无法打开文件“opencv_ts300d.lib”问题

热门文章

  1. 闲话Cache:始篇
  2. rpm包的管理
  3. MFC 学习 之 工具栏的添加(一)
  4. AutoCAD 2007在win8.1安装出现——错误1606。无法访问网络位置Autodesk\AutoCAD2007\R17.0\chs\的解决
  5. IPv6 相关的工作简介
  6. Java 多线程编程两个简单的样例
  7. open和fopen的区别
  8. 几种 HtmlEncode 的区别(转发)
  9. Linq lamda表达式Single和First方法
  10. 给大家普及一下CPU和SOC的基本知识,好让大家在盲目喝彩做出基本的判断