瀑布流这个概念一直不是很理解,看到别人可以实现,自己弄了很久还是不能实现就很纠结。瀑布流这根刺就一直扎在我心里,一次偶然的机会看到别人实现了瀑布流,我想我是不是也应该再继续把这个未完成的任务画一个圆满符号?所以坚持加上强迫自己好好思考,这里引用了别人瀑布流的图片(ps:没有去看实现方法,那些js代码看着晕乎乎的,没jquery简单,@_@)。

  在这里我采用了我认为简单的方法实现它,可能还有很多问题,希望大家能积极指正,谢谢~ O(∩_∩)O。

一、css代码

            .box-inner {
position: relative;
width: 1800px;
margin: 50px auto;
background: red;
}
.box-inner ul li {
position: absolute;
padding-bottom: 10px;
border: 2px solid gray;
text-align: center;
}

二、html代码

<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="../jquery-1.10.2.js"></script>
<link rel="stylesheet" href="../reset.css"/>
</head>
<body>
<div class="box">
<div class="box-inner">
<ul>
<li><img src="data:images/image_1.jpg"/><p>1</p></li>
<li><img src="data:images/image_2.jpg"/><p>2</p></li>
<li><img src="data:images/image_3.jpg"/><p>3</p></li>
<li><img src="data:images/image_4.jpg"/><p>4</p></li>
<li><img src="data:images/image_5.jpg"/><p>5</p></li>
<li><img src="data:images/image_6.jpg"/><p>6</p></li>
<li><img src="data:images/image_7.jpg"/><p>7</p></li>
<li><img src="data:images/image_8.jpg"/><p>8</p></li>
<li><img src="data:images/image_9.jpg"/><p>9</p></li>
<li><img src="data:images/image_10.jpg"/><p>10</p></li>
<li><img src="data:images/image_1.jpg"/><p>11</p></li>
<li><img src="data:images/image_2.jpg"/><p>12</p></li>
<li><img src="data:images/image_3.jpg"/><p>13</p></li>
<li><img src="data:images/image_4.jpg"/><p>14</p></li>
<li><img src="data:images/image_5.jpg"/><p>15</p></li>
<li><img src="data:images/image_6.jpg"/><p>16</p></li>
<li><img src="data:images/image_7.jpg"/><p>17</p></li>
<li><img src="data:images/image_8.jpg"/><p>18</p></li>
<li><img src="data:images/image_9.jpg"/><p>19</p></li>
<li><img src="data:images/image_10.jpg"/><p>20</p></li>
<li><img src="data:images/image_1.jpg"/><p>21</p></li>
<li><img src="data:images/image_2.jpg"/><p>22</p></li>
<li><img src="data:images/image_3.jpg"/><p>23</p></li>
<li><img src="data:images/image_4.jpg"/><p>24</p></li>
<li><img src="data:images/image_5.jpg"/><p>25</p></li>
</ul>
</div>
</div> </body>
</html>

三、jquery代码

$(function(){
var i = 0;
var next = 0;
$(".box-inner ul li").each(function(){
var width = $(this).width();
var allWidth = width*i;/* 表示所有图片总宽度 */
if(allWidth<1800){/* 表示为第一行 */
var cssObj = {"left":allWidth};
$(this).css(cssObj);
i++;
next = i;/* 将i值赋给next,当换行时next一行总数就保持不变了 */
}else{
/* 这边获取到的next就是每行总个数 */
var height = $(".box-inner ul li").eq(i-next).height()+$(".box-inner ul li").eq(i-next).offset().top-$(".box-inner").offset().top;/* 图片上一行对应地方的高度加上它上面偏移top减去box-inner偏移高度 */
var newLineWidth = width*(i%next);/* 每一行显示宽度的形式都是一样的,i整除next的值是0,1,2,... */
var otherObj = {"left":newLineWidth,"top":height};
$(this).css(otherObj);
i++;
}
});
});

jquery实现简单瀑布流的更多相关文章

  1. jquery实现简单瀑布流代码

    测试环境:ie8 ff13.0.1  chrome22 可以将分页获取的内容依次填入四个div中,瀑布流的分页可以以多页(比如5页)为单位二次分页,这样可以减少后台算法的复杂度 <!DOCTYP ...

  2. Jquery实现图片瀑布流思路-简单版

    目录 Jquery实现图片瀑布流思路-简单版 1.预备 2.开始 1.声明 2.主体 3.窗体大小改变事件 Jquery实现图片瀑布流思路-简单版 注意:本篇文章基于知道每张图片的实际尺寸的情况下 特 ...

  3. jquery实现简单瀑布流布局(续):图片懒加载

    # jquery实现简单瀑布流布局(续):图片懒加载 这篇文章是jquery实现简单瀑布流布局思想的小小扩展.代码基于前作的代码继续完善. 图片懒加载就是符合某些条件时才触发图片的加载.最常见的具体表 ...

  4. jquery实现简单瀑布流布局

    jquery实现简单瀑布流布局 是开头都会说的原理 瀑布流布局有两种,一种是固定列,一种是非固定列.在此主要记述第一种的实现. 固定列的特征是:无论页面如何缩放,每行的总列数都一致. 一行4列的瀑布流 ...

  5. jQuery无限载入瀑布流 【转载】

    转载至 http://wuyuans.com/2013/08/jquery-masonry-infinite-scroll/ jQuery无限载入瀑布流 好久没更新日志了,一来我比较懒,二来最近也比较 ...

  6. jQuery动态网格瀑布流插件Masonry

    Masonry是一款非常强大的jQuery动态网格布局插件,可以帮助开发人员快速开发瀑布流界面效果.和CSS中float的效果不太一样的地方在于,float先水平排列,然后再垂直排列,使用Masonr ...

  7. iOS之简单瀑布流的实现

    iOS之简单瀑布流的实现   前言 超简单的瀑布流实现,这里说一下笔者的思路,详细代码在这里. 实现思路 collectionView能实现各中吊炸天的布局,其精髓就在于UICollectionVie ...

  8. jquery插件实现瀑布流

    jquery插件实现瀑布流<!DOCTYPE html><html lang="en"><head> <meta charset=&quo ...

  9. jQuery淡入淡出瀑布流效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. Rhythmk 一步一步学 JAVA(7): jsp 自定义标签

    1.实现Tag接口: TagSupport类实现了Tag接口,为我们提供了4个重要的方法(见表6-5). 1.1. TagSupport类中的常用方法           int doStartTag ...

  2. Markdown之表格的处理

    目前编辑器不支持表格,以往是通过截图,呈现的效果并不好,Markdown支持html,所以我们可以用html来写表格.但是......用html写表格,实在太麻烦了,这里有个简单的转换方法,供大家参考 ...

  3. JS中如何获取当前时间及让时间格式化

    JS中获取当前时间和JAVA里获取当前时间一样,都是直接new Date即可.不同的是,JS中用var date=new Date();JAVA中用Data data=new Date();注:JS中 ...

  4. Windows下DOS命令大全(经典收藏)

    copy \\ip\admin$\svv.exe c:\ 或:copy\\ip\admin$\*.* 复制对方admini$共享下的srv.exe文件(所有文件)至本地C: xcopy 要复制的文件或 ...

  5. 【原】Coursera—Andrew Ng机器学习—课程笔记 Lecture 13—Clustering 聚类

    Lecture 13 聚类 Clustering 13.1 无监督学习简介  Unsupervised Learning Introduction 现在开始学习第一个无监督学习算法:聚类.我们的数据没 ...

  6. 添加 MyEclipse Persistence Tools 类库

    1).右键点击你的项目,然后选择Properties.2).在 Java Build Path 页面, 在 Libraries 面板下选择 Add Library….3).选择 MyEclipse L ...

  7. windows下python安装Numpy和Scipy模块

    安装 numpy: 去 http://sourceforge.net/projects/numpy/files/latest/download?source=files 下载相应的exe安装文件. 安 ...

  8. 144. Binary Tree Preorder Traversal (Tree, Stack)

    Given a binary tree, return the preorder traversal of its nodes' values. For example: Given binary t ...

  9. CloudStack 虚拟机控制台报错

    Access denied. Invalid web session or API key in request     解决此问题的方法是: 修改cloudstac.core.callback.js ...

  10. R Markdown 速查表