Html - 瀑布流
瀑布流,又称瀑布流式布局。是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部。最早采用此布局的网站是Pinterest,逐渐在国内流行开来。国内大多数清新站基本为这类风格。
waterwall.js
$(function(){
WaterWall("main","box");
Add_WaterWall_ScrollEvent("main","box");
})
function WaterWall(Id_name,Class_name)
{
var Box_Array = $("#"+ Id_name + ">." + Class_name); //获取所有的Box对象数组
]).innerWidth(); //获取Box的宽度.一定要包含Padding的数值
var Cols = Math.floor($(document).width() / Box_Width);
$("#"+ Id_name ).css({"width":Cols * Box_Width,"margin":"auto"}); //设置Main的宽度并且居中
var Height_Array = [] ;//存放每个列的的高度的数组
;i<Box_Array.length;i++)
{
if(i<Cols) //将第一行作为列高度的初始值添加到数组中
{
Height_Array.push($(Box_Array[i]).innerHeight());
}
else
{
var min = Math.min.apply(null,Height_Array); //获取列高度数组中最小值
var min_index = get_index(Height_Array,min); //获取指定数组中的最小值的索引
$(Box_Array[i]).css({"position":"absolute","top":min,"left":Box_Width * min_index + "px"});
Height_Array[min_index] += $(Box_Array[i]).innerHeight();
}
}
}
//获取指定数组中的最小值的索引
function get_index(arr,val)
{
for(var i in arr)
{
if(arr[i] == val)
{
return i; //获取列高度数组中最小值的索引
}
}
}
function Add_WaterWall_ScrollEvent(Id_name,Class_name)
{
//绑定一个滚动事件
$(window).scroll(function()
{
var Box_Array = $("#"+ Id_name + ">." + Class_name); //获取所有的Box对象数组
//最后一个box距离顶部的距离 + 图片的一半高度
).offset().top + $(Box_Array).eq(Box_Array.length - ).innerHeight() / ) ;
var scrolltop = $("body,html").scrollTop(); //浏览器拖动的距离
var see_height = document.body.clientHeight || document.documentElement.clientHeight; //浏览器可视距离
if(lastbox_height < Math.floor(scrolltop +see_height))
{
var temp = _.template($("#temp").html()); //模板
var data = {
"img":[
{"src":"Images/P_00.jpg"},
{"src":"Images/P_01.jpg"},
{"src":"Images/P_02.jpg"},
{"src":"Images/P_03.jpg"},
{"src":"Images/P_04.jpg"},
{"src":"Images/P_05.jpg"},
{"src":"Images/P_06.jpg"},
{"src":"Images/P_07.jpg"},
{"src":"Images/P_08.jpg"}
],
"text":[
{"title":"Images/P_00.jpg"},
{"title":"Images/P_01.jpg"},
{"title":"Images/P_02.jpg"},
{"title":"Images/P_03.jpg"},
{"title":"Images/P_04.jpg"},
{"title":"Images/P_05.jpg"},
{"title":"Images/P_06.jpg"},
{"title":"Images/P_07.jpg"},
{"title":"Images/P_08.jpg"}
]
}; //模拟后台JSON数据
;i<data.img.length;i++)
{
$("#"+ Id_name).append
(
temp({
src : data.img[i].src
})
)
}
WaterWall(Id_name,Class_name);
}
})
}
html:
<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title></title>
<link rel="stylesheet" href="Css/Basic.css" />
<script type="text/javascript" src="Js/jquery-2.1.1.min.js"></script>
<script type="text/javascript" src="Js/underscore-min.js"></script>
<script type="text/javascript" src="Js/waterwall.js"></script>
<style type="text/css">
#main
{
position:relative;
}
.box
{
float:left;
padding:15px 0px 0px 15px; /* 只需要上,左两个方向的间隔即可 */
}
.pic
{
border:1px solid #ccc;
padding:10px;
border-radius:15px;
box-shadow:0px 0px 15px #ccc;
}
.pic>img
{
width:165px;
height:auto;
}
</style>
</head>
<body>
<div id="main">
<div class="box">
<div class="pic">
<img src="Images/P_00.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_01.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_02.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_03.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_04.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_05.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_06.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_07.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_08.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_09.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_010.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_011.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_012.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_013.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_014.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_015.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_016.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_017.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_018.jpg" alt="" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="Images/P_019.jpg" alt="" />
</div>
</div>
</div>
</body>
</html>
http://www.imooc.com/learn/101
Html - 瀑布流的更多相关文章
- jquery瀑布流的制作
首先,还是来看一下炫酷的页面: 今天就边做边说了: 一.准备工作 新建css,js,img文件夹存放相应文件,并在demo.html文件中引入外部文件(注意要把jquery文件引入),这里就不过多描述 ...
- js瀑布流 原理实现揭秘 javascript 原生实现
web,js瀑布流揭秘 瀑布流再很久之前流行,可能如我一样入行晚的 ,可能就没有机会去使用.但是这个技术终究是个挺炫酷的东西,花了一个上午来研究,用原生js实现了一个,下面会附上源码,供大家解读. 说 ...
- CollectionView水平和竖直瀑布流的实现
最近在项目中需要实现一个水平的瀑布流(即每个Cell的高度是固定的,但是长度是不固定的),因为需要重写系统 UICollectionViewLayout中的一些方法通过计算去实现手动布局,所以本着代码 ...
- 用jquery实现瀑布流案例
一.瀑布流是我们常见的案例,这里主要讲述,用jquery的方式实现瀑布流的功能! 引言:我们经常见到很多网站的瀑布流功能,如淘宝.京东这些商品等等.. 实现它我们首先考虑几个问题:1.获取到数据 ...
- RecylerView完美实现瀑布流效果
RecylerView包含三种布局管理器,分别是LinearLayoutManager,GridLayoutManager,StaggeredGridLayoutManager,对应实现单行列表,多行 ...
- 飞流直下的精彩 -- 淘宝UWP中瀑布流列表的实现
在淘宝UWP中,搜索结果列表是用户了解宝贝的重要一环,其中的图片效果对吸引用户点击搜索结果,查看宝贝详情有比较大的影响.为此手机淘宝特意在搜索结果列表上采用了2种表现方式:一种就是普通的列表模式,而另 ...
- iOS瀑布流实现(Swift)
这段时间突然想到一个很久之前用到的知识-瀑布流,本来想用一个简单的方法,发现自己走入了歧途,最终只能狠下心来重写UICollectionViewFlowLayout.下面我将用两种方法实现瀑布流,以及 ...
- 瀑布流StaggeredGridView 下拉刷新
1.项目中用到了瀑布流,之前用的是PinterestLikeAdapterView这个控件 然后上拉加载更多跟下拉刷新用的是XListView ,但是加载更多或者下拉刷新的时候闪屏,对用户体验很不好 ...
- iOS开发之窥探UICollectionViewController(四) --一款功能强大的自定义瀑布流
在上一篇博客中<iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流>,自定义瀑布流的列数,Cell的外边距,C ...
- iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流
上篇博客的实例是自带的UICollectionViewDelegateFlowLayout布局基础上来做的Demo, 详情请看<iOS开发之窥探UICollectionViewControlle ...
随机推荐
- codeforces 478B Random Teams 解题报告
题目链接:http://codeforces.com/problemset/problem/478/B 题目意思:有 n 个人,需要将这班人分成 m 个 组,每个组至少含有一个人,同一个组里的人两两可 ...
- 解决java.lang.UnsupportedClassVersionError
出现java.lang.UnsupportedClassVersionError 错误的原因,是因为我们使用高版本的JDK编译的Java class文件试图在较低版本的JVM上运行,所报的错误. 版本 ...
- Hibernate常见问题
问题1,hql条件查询报错 执行Query session.createQuery(hql) 报错误直接跳到finally 解决方案 加入 <prop key="hibernate.q ...
- 什么是网络爬虫(Spider) 程序
Spider又叫WebCrawler或者Robot,是一个沿着链接漫游Web 文档集合的程序.它一般驻留在服务器上,通过给定的一些URL,利用HTTP等标准协议读取相应文档,然后以文档中包括的所有未访 ...
- Linux创建用户并赋予Root权限
添加普通用户 [root@server ~]# useradd test //添加一个名为test的用户[root@server ~]# passwd test //修改密码Changing pass ...
- Virtual Box创建共享目录
1.先关闭ubuntu,在virtualbox“设置”中找到“共享文件夹”,点击进入,点击右边添加目录按钮,添加windows中要共享的目录,取一个名.比如我在D盘建一个名为share的文件夹,如下图 ...
- spring classpath & classpath*
classpath-找到系统类路径下的第一个匹配的配置文件 classpath*-找到系统类路径下的所有符合要求的配置文件 参考资料:http://www.micmiu.com/j2ee/spring ...
- Hibernate 分页时 Long 无法转化成Integer类型 异常
转自:http://loquat.iteye.com/blog/818547 报错:java.lang.Long cannot be cast to java.lang.Integer Long ...
- 让/etc/profile文件修改后立即生效(转)
方法1:让/etc/profile文件修改后立即生效 ,可以使用如下命令:# . /etc/profile注意: . 和 /etc/profile 有空格方法2:让/etc/profile文件修改后 ...
- SQL Server 2005 中实现通用的异步触发器架构
在SQL Server 2005中,通过新增的Service Broker可以实现异步触发器的处理功能.本文提供一种使用Service Broker实现的通用异步触发器方法. 在本方法中,通过Serv ...