弘帝企业智能建站系统交流平台

 找回密码
 立即注册
查看: 2167|回复: 0

瀑布流无限加载图片插件jq-waterfall

[复制链接]
发表于 2020-1-23 09:56:46 | 显示全部楼层 |阅读模式
jq-waterfall是一款仿Pinterest网站的响应式无限动态加载图片瀑布流特效jQuery插件。该瀑布流特效使用ajax调用来动态加载图片,达到无限加载的效果。它使用简单,兼容性好,值得推荐!
使用方法
使用这个瀑布流插件需要引入jQuery和jquery.waterfall.js文件。
  1. <script src="js/jquery-1.11.1.min.js"></script>
  2. <script src="js/jquery.waterfall.js"></script>
复制代码


HTML结构
该瀑布流特效的HTML结个使用一个<div>来包裹图片,然后在外围使用一个<div>作为包裹容器。
  1. <div id="demo">
  2.   <div class="box"><img src="img/01.jpg" alt=""></div>
  3.   <div class="box"><img src="img/02.jpg" alt=""></div>
  4.   <div class="box"><img src="img/03.jpg" alt=""></div>
  5.   ...
  6. </div>
复制代码



CSS样式
DEMO中给出了这个瀑布流的基本样式,你可以自行修改为你需要的瀑布流样式。
  1. #demo {
  2.   margin: auto;
  3.   position: relative;
  4. }
  5.   
  6. .box {
  7.   float: left;
  8.   padding: 10px;
  9.   border: 1px solid #ccc;
  10.   background: #f7f7f7;
  11.   box-shadow: 0 0 8px #ccc;
  12. }
  13.   
  14. .box:hover { box-shadow: 0 0 10px #999; }
  15.   
  16. .box img { width: 200px; }
复制代码

调用插件
插件使用Javascript来生成Pinterest样式的网格瀑布流布局。使用ajaxCallback来在页面向下滚动的时候对图片进行动态加载,以达到无限瀑布流的效果。
  1. $("#demo").waterfall({
  2.   itemClass: ".box",
  3.   minColCount: 2,
  4.   spacingHeight: 10,
  5.   resizeable: true,
  6.   ajaxCallback: function(success, end) {
  7.     var data = {"data": [
  8.       { "src": "03.jpg" }, { "src": "04.jpg" }, { "src": "02.jpg" }, { "src": "05.jpg" }, { "src": "01.jpg" }, { "src": "06.jpg" }
  9.     ]};
  10.     var str = "";
  11.     var templ = '<div class="box" style="opacity:0;filter:alpha(opacity=0);"><div class="pic"><img src="img/{{src}}" /></div></div>'
  12.   
  13.     for(var i = 0; i < data.data.length; i++) {
  14.       str += templ.replace("{{src}}", data.data[i].src);
  15.     }
  16.     $(str).appendTo($("#div1"));
  17.     success();
  18.     end();
  19.   }
  20. });
复制代码



配置参数
下面是该瀑布流特效的可用参数。
参数
默认值
描述
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


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|弘帝企业智能建站系统 ( 皖ICP备07503252号 )

GMT+8, 2024-11-24 02:30 , Processed in 0.047290 second(s), 15 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表