参考刘晓帆大神的瀑布流效果 自己也写了个 希望能给打算写这个效果的朋友一点点思路,也希望朋友们批评指正!

html代码:

<!DOCTYPE html>
<html>
<head>
<script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="script.js"></script>
<link rel="stylesheet" href="style.css" />
</head>
<body>
<div class="z-box">
<ul>
<li>
<h3>1A</h3>
<a>aa</a>
<a>aa</a>
<a>aa</a>
</li>
<li>
<h3>2B</h3>
<a>bb</a>
</li>
<li>
<h3>3C</h3>
<a>cc</a>
<a>cc</a>
<a>cc</a>
<a>cc</a>
</li>
<li>
<h3>4D</h3>
<a>dd</a>
<a>dd</a>
<a>dd</a>
<a>dd</a>
<a>dd</a>
<a>dd</a>
<a>dd</a>
</li>
<li>
<h3>5E</h3>
<a>ee</a>
<a>ee</a>
<a>ee</a>
<a>ee</a>
<a>ee</a>
</li>
<li>
<h3>6F</h3>
<a>ff</a>
<a>ff</a>
<a>ff</a>
</li>
<li>
<h3>7G</h3>
<a>GG</a>
<a>GG</a>
<a>GG</a>
</li>
<li>
<h3>8E</h3>
<a>ee</a>
<a>ee</a>
<a>ee</a>
<a>ee</a>
<a>ee</a>
</li>
<li>
<h3>9F</h3>
<a>ff</a>
<a>ff</a>
<a>ff</a>
</li>
<li>
<h3>10G</h3>
<a>GG</a>
<a>GG</a>
<a>GG</a>
</li>
</ul>
</div>
</body>
</html>

css代码:

*{
margin:0px;
padding:0px;
font-size:12px;
}
body{
background:pink;
}
li{
list-style:none;
}
.z-box{
width:300px;
height:auto;
box-shadow:0px 0px 1px red;
margin:0 auto;
position:relative;
}
.z-box ul{ }
.z-box ul li{
width:44px;
text-align:center;
position:absolute;
background:#f3f3f3;
top:0px;
left:40%;
transition:all 0.5s;
-webkit-transition:all 0.5s;
-o-transition:all 0.5s;
-ms-transition:all 0.5s;
-moz-transition:all 0.5s; }
.z-box ul li a{
display:block;
width:44px; }

javascript代码:

$(function(){

    var $oLi=$(".z-box > ul li");    //jq对象
var dWidth=$(".z-box").outerWidth();
var lWidth=$oLi.outerWidth()+5; //li的宽度+间距
var col=Math.round(dWidth/(lWidth+10)); //列数+间距
console.log(col); var array=[]; //存放列坐标的数组 for(var i=0;i<col;i++){
array.push([i*lWidth,0]); //初始化列的坐标
} $oLi.each(function(){ //遍历每一个单位 var _temp=0; //最低列暂存体
var _height=$(this).outerHeight(); //获取当前单位的高度 for(var j=0;j<col;j++){
if(array[j][1]<array[_temp][1]){
_temp=j; //比较哪列是最低索引
}
} $(this).css({"left":array[_temp][0]+"px","top":array[_temp][1]+"px"}); //设置单位的坐标
array[_temp][1] = array[_temp][1] + _height+5; //计算列的最低坐标 }); //获取最高top
var nLi=[],
n=0,
max=0,
nHeight;
for(var i=0;i<col;i++){
if(array[i][1]>array[n][1]){
n=i;
max=array[i][1]-5;
}
} for(var j=0;j<col;j++){
if(array[j][1]>array[n][1]){
n=j;
$(".z-box").css("height",array[j][1]-5+"px");
console.log("min="+j); }else{
nHeight=max-array[j][1];
nLi[j]=document.createElement("li");
$(nLi[j]).css("height",nHeight);
$(nLi[j]).css({"left":array[j][0]+"px","top":array[j][1]+"px"});
$(".z-box > ul").append(nLi[j]);
console.log("max="+j);
}
}
});

瀑布流布局(jq实现)的更多相关文章

  1. 纯css瀑布流布局

    由于公司的项目需要才用到瀑布流布局 因为后台返回的json直接循环出来的,所以不能做左右浮动的那种,所以才用到了瀑布流布局 16年之前的瀑布流布局基本都时基于js或者直接用jq插件的,但是随着技术的进 ...

  2. JS瀑布流布局

    好久没有更新博客喽,今天来说一个瀑布流布局. 瀑布流在很多网站已有很多,现在只说一下简单的实现原理吧, 1.计算一行可以排放几个元素 2.建立一个数组用于存放第一行的每个元素的高度. 3.得到数组中的 ...

  3. CSS3学习总结——实现瀑布流布局与无限加载图片相册

    首先给大家看一下瀑布流布局与无限加载图片相册效果图: 一.pic1.html页面代码如下: <!DOCTYPE html> <html> <head> <me ...

  4. myWaterfall - jQuery瀑布流布局插件

    myWaterfall - jQuery瀑布流布局插件 Demo http://jsfiddle.net/q3011893/p5k2ogy8/embedded/result,html,css,js/ ...

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

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

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

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

  7. JavaScript——基本的瀑布流布局及ajax动态新增数据

    本文用纯js代码手写一个瀑布流网页效果,初步实现一个基本的瀑布流布局,以及滚动到底部后模拟ajax数据加载新图片功能. 缺点: 1. 程序不是响应式,不能实时调整页面宽度: 2. 程序中当新增ajax ...

  8. flexbox实现不等宽不等高的瀑布流布局

    第一次做不等宽不等高的瀑布流布局,刚开始企图用ccs3的column属性+flexbox来实现,瞎捣鼓半天都没有能弄好, 弱鸡哭晕在厕所(┬_┬),气的午饭都没有吃. 后来逼着自己冷静下来,又捣鼓了1 ...

  9. 通过Measure & Arrange实现UWP瀑布流布局

    简介 在以XAML为主的控件布局体系中,有用于完成布局的核心步骤,分别是measure和arrange.继承体系中由UIElement类提供Measure和Arrange方法,并由其子类Framewo ...

随机推荐

  1. Install Sublime Text 3

    $ sudo add-apt-repository ppa:webupd8team/sublime-text-3 $ sudo apt-get update $ sudo apt-get instal ...

  2. WebView 的使用----android 网络连接处理分析

    在Android中,可以有多种方式来实现网络编程: 创建URL,并使用URLConnection/HttpURLConnection 使用HttpClient 使用WebView 创建URL,并使用U ...

  3. 【 2013 Multi-University Training Contest 5 】

    HDU 4647 Another Graph Game 如果没有边的作用,显然轮流拿当前的最大值即可. 加上边的作用,将边权平均分给两个点,如果一个人选走一条边的两个点,就获得了边的权值:如果分别被两 ...

  4. 【C#】 格式化说明符 string.Format WriteLine

    定义 格式说明符的语法由3个字段组成:索引号.对齐说明符和格式字段.String.Format和WriteLine都遵守同样的格式化规则. 对齐说明符 对齐说明符表示了字段中字符的最小宽度.对齐说明符 ...

  5. HOJ 1001: A+B; 1002: A+B+C

    两道水题,用来熟悉 HOJ 的提交系统. 1001:输入两个整数 A, B (0 <= A,B <= 10),输出 A+B. #include <iostream> using ...

  6. Devexpress DateEdit控件的值不反馈到数据源的处理方式。

    如果在GridControl中要把编辑的值反馈到数据源,可以用Gridview1.PostEdit()方法. 可是在datalayout中使用就会遇到一些问题:比如说DateEdit控件,在保存数据的 ...

  7. jsp中的正则表达式

    sp中${}----是EL表达式的常规表示方式目的是为了获取{}中指定的对象(参数.对象等)的值如:${user.name}<====>User user = (User)request( ...

  8. MVC 请求处理流程(一)

    路由系统先获取路由数据,在实现了IHttpModule接口的UrlRoutingModule对象中通过注册HttpApplication的PostResolveRequestCache来解析路由数据并 ...

  9. STM32 HAL固件库编程的文件构架

    对于我这种以前只接触过51和AVR单片机编程的小菜来说,现在开始学习STM32的编程,对于函数的功能以及C语言的语法都还好理解,难的是它提供的那一套硬件抽象层(HAL)驱动是怎么和其他的东东搭配在一起 ...

  10. 区分苹果Safari浏览器

    区分苹果Safari浏览器 (function() { var Sys = {}; var ua = navigator.userAgent.toLowerCase(); var s; (s = ua ...