waterfall是一款响应式无限动态加载图片瀑布流特效jQuery插件。 waterfall瀑布流特效使用ajax调用来动态加载图片,达到无限加载的效果。jquery
使用这个瀑布流插件须要引入jQuery.min.js和jquery.waterfall.js文件。ajax
<script src="js/jquery-1.11.1.min.js"></script>
<script src="js/jquery.waterfall.js"></script>
复制代码
HTML结构
该瀑布流特效的HTML结个使用一个<div>
来包裹图片,而后在外围使用一个<div>
做为包裹容器。浏览器
<div id="demo">
<div class="box"><img src="img/01.jpg" alt=""></div>
<div class="box"><img src="img/02.jpg" alt=""></div>
<div class="box"><img src="img/03.jpg" alt=""></div>
...
</div>
复制代码
CSS样式
DEMO中给出了这个瀑布流的基本样式,你能够自行修改成你须要的瀑布流样式。bash
#demo {
margin: auto;
position: relative;
}
.box {
float: left;
padding: 10px;
border: 1px solid #ccc;
background: #f7f7f7;
box-shadow: 0 0 8px #ccc;
}
.box:hover { box-shadow: 0 0 10px #999; }
.box img { width: 200px; }
复制代码
调用插件
插件使用Javascript来生成网格瀑布流布局。使用ajaxCallback来在页面向下滚动的时候对图片进行动态加载,以达到无限瀑布流的效果。网络
$("#demo").waterfall({
itemClass: ".box",
minColCount: 2,
spacingHeight: 10,
resizeable: true,
ajaxCallback: function(success, end) {
var data = {"data": [
{ "src": "03.jpg" }, { "src": "04.jpg" }, { "src": "02.jpg" }, { "src": "05.jpg" }, { "src": "01.jpg" }, { "src": "06.jpg" }
]};
var str = "";
var templ = '<div class="box" style="opacity:0;filter:alpha(opacity=0);"><div class="pic"><img src="img/{{src}}" /></div></div>'
for(var i = 0; i < data.data.length; i++) {
str += templ.replace("{{src}}", data.data[i].src);
}
$(str).appendTo($("#div1"));
success();
end();
}
});
复制代码
演示demo
传送门,点击查看demoapp
配置参数
下面是waterfall.js该瀑布流特效的可用参数函数
参数 | 默认值 | 描述 |
itemClass | "waterfall-item" | 图片网格元素的class名称 |
spacingWidth | 10 | 图片网格元素的水平间距 |
spacingHeight | 10 | 图片网格元素的垂直间距 |
minColCount | 2 | 瀑布流布局的最小列数 |
resizeable | false | 是否在浏览器窗口缩放时触发positionAll()方法 |
itemAlign | "center" | 图片网格元素的对齐方式,可选:center|left |
isFadeIn | true | 是否在加载图片时使用淡入淡出效果 |
ajaxCallback | null | ajax回调函数,有2个可用参数:success, end |
本文章摘抄于网络,自我学习笔记更新,感谢原是做者分享!布局