瀑布流这个概念一直不是很理解,看到别人可以实现,自己弄了很久还是不能实现就很纠结。瀑布流这根刺就一直扎在我心里,一次偶然的机会看到别人实现了瀑布流,我想我是不是也应该再继续把这个未完成的任务画一个圆满符号?所以坚持加上强迫自己好好思考,这里引用了别人瀑布流的图片(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. [Z] 一些关于http服务器架构设计的资料

    开始关注这块儿,先从最基础最简单的入手.这里放一些我看过的觉得可以收藏的资料,主要是网页或博客,经典书籍之类有时间再看吧: 风格之争:Coroutine模型 vs 非阻塞/异步IO(callback)

  2. ansible初识三

    一.setup模块 ansible的 setup模块主要用来收集信息, 查看参数: [root@localhost ~]# ansible-doc -s setup # 查看参数,部分参数如下: fi ...

  3. Android 4 学习(17):使用Content Resolver

    Content Resolver简介 每个应用程序都有一个ContentResolver实例,通过getContentResolver()方法可以获取: ContentResolver cr = ge ...

  4. JAVASCRIPT数据类型(值类型-引用类型-类型总览)

    值类型:也称为原始数据或原始值(primitive value). 这类值存储在栈(stack)中,栈是内存中一种特殊的数据结构,也称为线性表,栈按照后进先出的原则存储数据,先进入的数据被压入栈底,最 ...

  5. 开始使⽤ZooKeeper的API

    在之前的章节中,我们使用zkCli工具介绍了ZooKeeper的基本操作.从本章开始,我们将会看到在应用中如何通过API来进行操作.首先介绍一下如何使用ZooKeeper的API进行开发,展示如何创建 ...

  6. JSTL之C标签的用法

    转自:https://my.oschina.net/zimingforever/blog/78980 最近开始整理以前的onenote,居然有200多篇,大致翻了下,很多内容都是在大学的时候学习的时候 ...

  7. android游戏的增量更新(资源及代码的热更新)

    需求当游戏需要更新时,不必让用户下载新的完整包,只需要通过游戏内部的更新系统自动更新差异包,达到节约用户流量和时间的目的. 大体思路:1.(游戏逻辑用lua等脚本编写的情况)这种方式的增量更新非常简单 ...

  8. aws s3 python sdk

    http://boto3.readthedocs.io/en/latest/reference/services/s3.html#S3.Client.get_object abort_multipar ...

  9. JAVA集合中的迭代器的遍历

    JAVA中的迭代器,迭代实质上就是遍历,在JAVA中使用iterator()方法进行迭代.需要注意的是,iterator()方法的返回值是Iterator对象.Iterator对象有三个方法,hasN ...

  10. Ant学习--简单实例入门

    步骤1.创建工程文件夹名字 F:\Helloworld 步骤2.编写java代码: package com.netease; public class Ant_test { public static ...