瀑布流函数
2016-03-15 15:30
239 查看
在jQuery对象后面添加瀑布流函数
[相关资料][]https://github.com/PaddyWang/study/tree/master/%E7%80%91%E5%B8%83%E6%B5%81%E6%95%88%E6%9E%9C]
(function($){ $.fn.waterFall = function(gap){ // 函数调用对象 jQuery对象 var $this = $(this), // 调用对象子元素集合 jQuery对象 $items = $this.children(), // 总宽度 sumWidth = $this.width(), // 子元素的宽度 width = $items.width(), // 子元素高度 height = 0, // 两个子元素之间的间距 默认20 gap = gap || 20, // 总列数 column = Math.floor(sumWidth / (width + gap)), // 每列的高度数组集合 arrHeight = []; // 遍历子元素 $items.each(function(key , val){ // 获取每个子元素的高度 height = $(val).height(); // 第一行 if(key < column){ // 把第一行的子元素高度添加到数组中 arrHeight[key] = height; // 第一行 子元素 top = 0 left = 为当前索引*(子元素宽度+两个元素之间的间距) $(val).css({ 'top':0, 'left':key * (width + gap) }); // 其他行 }else { // 查找高度 最小值 // 先给以个默认索引 即 0 var minIndex = 0; var minHeight = arrHeight[minIndex]; // 遍历高度数组 for(var i in arrHeight){ // 判断最小值 if(minHeight > arrHeight[i]){ // 替换最小值索引及最小值 minIndex = i; minHeight = arrHeight[i]; } } // 其他行 top = 每列中的最小值 即最低的那一列 $(val).css({ 'top':minHeight, 'left':minIndex * (width + gap) }); // 修改高度数组 最小高度 = 最小高度 + 当前子元素高度 arrHeight[minIndex] = minHeight + height; } }); // 查找高度 最大值 var maxIndex = 0, maxHeight = arrHeight[maxIndex]; for(var i in arrHeight){ if(maxHeight < arrHeight[i]){ maxIndex = i; maxHeight = arrHeight[i]; } } } })(jQuery) // 调用函数 // $('.items').waterFall();
[相关资料][]https://github.com/PaddyWang/study/tree/master/%E7%80%91%E5%B8%83%E6%B5%81%E6%95%88%E6%9E%9C]
相关文章推荐
- makefile中的自动化变量 【转】
- [JavaEE笔记]Cookie
- Swift 2.0 UItableView 的简单使用
- Java并发编程:进程和线程的由来(转)
- Spring,hibernate,struts的面试笔试题及答案
- JS获取某年某月的最后一天
- PHp服务器环境搭建
- 《小怨念》
- 原地归并排序
- java的面试题
- 常用 Git 命令清单
- poj 3468 A Simple Problem with Integers(线段树 插线问线)
- poj 3468 A Simple Problem with Integers(线段树 插线问线)
- Windows+Git+TortoiseGit+COPSSH 安装图文教程
- android 4.3之后使用ccache提供编译速度
- JAVA jacob office转换pdf代码
- 归并排序
- H5中新增API-历史管理&Web应用&应用缓存
- centOS安装firefox浏览器
- C#第十六节课