zoukankan      html  css  js  c++  java
  • 简单的waterfall

    文章从http://www.jianshu.com/p/6b59367cf53a节选出来

    知识点汇总:

    outerWidth()是计算一个容器的大小,包括盒子的基本宽度和padding和border和margin(可选),如果设置outerWidthW(true),则算上margin值

     1 <style>
     2         .box{
     3             width: 100%;
     4             margin: 0;
     5             position: relative;
     6         }
     7         .item{
     8             transition: all 1s;
     9             width: 200px;
    10             margin-right: 10px;
    11             margin-bottom: 10px;
    12             position: absolute;
    13         }
    14         .part1{
    15             background-color: yellow;
    16             height: 100px;
    17         }
    18         .part2{
    19             background-color: skyblue;
    20             height: 200px;
    21         }
    22         .part3{
    23             background-color: orange;
    24             height: 300px;
    25         }
    26     </style>
    27 
    28     <div class="box">
    29         <div class="item part1">1</div>
    30         <div class="item part2">1</div>
    31         <div class="item part3">1</div>
    32         <div class="item part3">1</div>
    33         <div class="item part3">1</div>
    34         <div class="item part2">1</div>
    35         <div class="item part1">1</div>
    36         <div class="item part3">1</div>
    37         <div class="item part2">1</div>
    38         <div class="item part1">1</div>
    39         <div class="item part2">1</div>
    40         <div class="item part3">1</div>
    41         <div class="item part1">1</div>
    42         <div class="item part2">1</div>
    43         <div class="item part1">1</div>
    44     </div>
     1 <script src="jquery-3.2.1.js"></script>
     2     <script>
     3         function waterfall(){
     4             var allColumns = parseInt($(".box").width()/$(".item").outerWidth(true));
     5             // 计算总的列数
     6             console.log(allColumns);
     7             var allHeight=[];
     8             // 定义一个数组,存放所有的列的高度
     9             for(var i=0;i<allColumns;i++){
    10                 allHeight.push(0);
    11                 // 初始化所有的高度
    12             }
    13             console.log(allHeight);
    14             $(".item").each(function(){
    15                 var $cur= $(this);
    16                 var minHeight = allHeight[0];
    17                 // 假设第一个高度是最小的
    18                 var column=0;
    19                 // 为后面找到最矮的那列做准备
    20                 for(var j=0;j<allHeight.length;j++){
    21                     if(allHeight[j]<minHeight){
    22                         minHeight = allHeight[j];
    23                         // 找出最矮的那列的高度
    24                         column = j;
    25                         // 找出最矮的那列时第几列
    26                     }
    27                 }
    28                 $cur.css({
    29                     "left":column*$cur.outerWidth(true),
    30                     "top":minHeight
    31                 });
    32                 console.log(j*$(".item").outerWidth(true))
    33                 allHeight[column]=minHeight+$cur.outerHeight(true);
    34                 // 添加元素之后,最矮的那列的高度应该变为原始值加上新加上元素的高度值
    35             })
    36         }
    37         waterfall();
    38         window.onresize=function(){
    39             waterfall();
    40         }
    41     </script>

    最后效果为:

  • 相关阅读:
    STM32 IAP程序 源码 和测试代码 有详细的中文注释
    mysql读写分离配置,利用mybatis实现,解释为什么dynamicDataSource不行
    mysql主从复制的配置总结
    Chapter 2 Open Book——7
    leetcode415---字符串大数相加
    Chapter 2 Open Book——6
    leetcode83,删除有序链表中的重复元素
    Chapter 2 Open Book——5
    Chapter 2 Open Book——4
    leetcode24,交换链表相邻的节点
  • 原文地址:https://www.cnblogs.com/cyany/p/7600501.html
Copyright © 2011-2022 走看看