博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
瀑布流布局--jQuery写法
阅读量:6059 次
发布时间:2019-06-20

本文共 2704 字,大约阅读时间需要 9 分钟。

HTML

1 
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32

CSS

1 * { 2     margin: 0; 3     padding: 0; 4 } 5 #main { 6     position: relative; 7  8 } 9 .box {10     padding:15px 0 0 15px;11     float:left;12 }13 .pic {14     padding: 10px;15     border: 1px solid #ccc;16     border-radius: 5px;17     box-shadow: 0px 0px 5px #ccc;18     img {19         width:165px;20         height:auto;21     }22 }

JavaScript

1 $(window).on("load",function () { 2     waterfall(); 3     var dataInt = { "data":[{"src":"7.jpg"},{"src":"8.jpg"},{"src":"9.jpg"},{"src":"6.jpg"}]} 4     //模拟json数据; 5     $(window).on("scroll",function () { 6         if(checkScrollSlide){ 7             $.each(dataInt.data,function (key,value) { 8                 var oBox=$("
").addClass("box").appendTo($("#main")); 9 //jQuery支持连缀,隐式迭代;10 var oPic=$("
").addClass('pic').appendTo($(oBox));11 $("
").attr("src","images/"+$(value).attr("src")).appendTo(oPic);12 });13 waterfall();14 }15 })16 });17 //流式布局主函数;18 function waterfall () {19 var $boxs=$("#main>div");20 //获取#main元素下的直接子元素div.box;21 22 //获取每一列的宽度;23 var w=$boxs.eq(0).outerWidth();24 //outerWidth()获取包含padding和border在内的宽度;25 //var w=$boxs.eq(0).width();26 //width()只能获取给元素定义的宽度;27 28 var cols=Math.floor($(window).width()/w);29 //获取多少列;30 $("#main").width(w*cols).css("margin","0 auto");31 //设置#main元素的宽度和居中样式;32 33 var hArr=[];34 //每一列高度的集合;35 $boxs.each(function (index,value) {36 //遍历每一个box元素;37 //为了找到之前所有元素的最低点,然后将本元素设置到最低点之下;38 var h=$boxs.eq(index).outerHeight();39 //每一个box元素的高,40 if (index
div").last();64 var lastBoxDis=$lastBox.offset().top+Math.floor($lastBox.outerHeight()/2);65 var scrollTop=$(window).scrollTop();66 var documentH=$(window).height();67 return (lastBoxDis

 

转载于:https://www.cnblogs.com/yizihan/p/4158436.html

你可能感兴趣的文章
ubuntu上配置Nginx+PHP5 FastCGI服务器配置
查看>>
Java+MyEclipse+Tomcat (一)配置过程及jsp网站开发入门
查看>>
PowerVault TL4000 Tape Library 告警:“Media Attention”
查看>>
数据仓库专题(23):总线矩阵的另类应用-Drill Down into a More Detailed Bus Matrix
查看>>
第2章番外2 令人惊喜的注释文档
查看>>
【Android开发】 Android Fragment应用实战(转)
查看>>
Sequelize 和 MySQL 对照
查看>>
超强、超详细Redis数据库入门教程
查看>>
MongoDB · 特性分析 · MMAPv1 存储引擎原理
查看>>
JAVA语言规范-线程和锁章节之同步、等待和通知
查看>>
python $variable substitute in string using string Template module
查看>>
脉冲控制收发
查看>>
删除内容同时删除富本编辑器上传的图片文件
查看>>
iOS高级开发(五)——国际化
查看>>
less注意点小记
查看>>
程序员的危机感
查看>>
Android 中的线程池简单理解
查看>>
问题MySQL server has gone away
查看>>
深度剖析一站式分布式事务方案Seata(Fescar)-Server
查看>>
Webpack的坑位整理
查看>>