zoukankan      html  css  js  c++  java
  • javascript瀑布流

    哇,瀑布流,是的,不错,不错,真的不错,很好玩的样子,于是自己想玩玩啊,来吧,就玩起。

    循序渐进,我这里采用原生的js代码来书写。为了方便大家运行代码,我就全部样式和CSS都写在html里面了,当然还需要图片,我会打包。

    来上代码。

    直接代码

    复制代码
    <!DOCTYPE HTML>
    <html>
        <head>
        <meta charset="utf-8">
        <title>哇,瀑布流啊</title>
        <style type="text/css">
        
           @media screen and (min-1550px){
                .waterfall-container {    
                     1400px;            
                }
            }
            
            @media screen and (max-1549px) and (min-1366px){
                .waterfall-container {
                     1200px;            
                }
            }
            @media screen and (max-1365px) and (min-700px) {
                .waterfall-container {
                     500px;            
                }
            }
            
            @media screen and (max-699px) {
                .waterfall-container {
                     350px;            
                }
            }
            
            .waterfall-container{                 
                top: 0;
                float:left;            
                display:inline;
                position:relative;
            }
            
            .water-molecule {
                 position:absolute;
                 border: solid 1px #ccc;
                 padding: 10px;
                  200px;
                 top: 0px;
                 left: 0px;
                 -webkit-transition: all .7s ease-out .1s;
                 -moz-transition: all .7s ease-out .1s;
                 -o-transition: all .7s ease-out .1s;
                 transition: all .7s ease-out .1s
            }
            img {  100%; }
        
            
        </style>
        </head>
        <body >
            <div>
                哟,好拽的瀑布流!!!
            </div>
            <div style="position:relative">
                <div style="left:0; float:left; display:inline; 100px">
                
                    <ul id="mediaSet">
                        <li><a href="#">1300px</a></li>
                        <li><a href="#">1100px</a></li>
                        <li><a href="#">900px</a></li>
                        <li><a href="#">600px</a></li>
                    </ul>
                
                </div>
                <div class="waterfall-container">
                      <div class="water-molecule"><a href="images/temp_img02.jpg"><img src="images/temp_img02.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img03.jpg"><img src="images/temp_img03.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img04.jpg"><img src="images/temp_img04.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img09.jpg"><img src="images/temp_img09.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img05.jpg"><img src="images/temp_img05.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img06.jpg"><img src="images/temp_img06.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img07.jpg"><img src="images/temp_img07.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img08.jpg"><img src="images/temp_img08.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img09.jpg"><img src="images/temp_img09.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img10.jpg"><img src="images/temp_img10.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img11.jpg"><img src="images/temp_img11.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img12.jpg"><img src="images/temp_img12.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img13.jpg"><img src="images/temp_img13.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img14.jpg"><img src="images/temp_img14.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img15.jpg"><img src="images/temp_img15.jpg"/></a> </div>
                      <div class="water-molecule"><a href="images/temp_img15.jpg"><img src="images/temp_img15.jpg"/></a> </div>
                      
                </div>
            </div>
    
        <script type="text/javascript">
        
            function minColunmnIndex (arr) {
                var minColumn = 0;
                var min = arr[minColumn];
                for (var i = 1,len=arr.length; i < len; i++) {
                    var temp = arr[i];
                    if (temp < min) {
                        minColumn = i;
                        min = temp;
                    };
                };
                return minColumn;
            }
            
            Object.extend = function(destination, source) {
                for (var property in source) {
                    destination[property] = source[property];
                }
                return destination;
            }
        
            function waterWall(container,settings){    
            
                var _settings = {
                    margin:10,
                    cellClass:"water-molecule"            
                };
                if(typeof settings != "undefined"){
                    _settings = Object.extend(_settings,settings);
                }
                var margin = _settings.margin;
                var boxes = document.getElementsByClassName(_settings.cellClass);
                var wContainer = container;
                var boxWidth = boxes[0].offsetWidth + margin;
                
                function waterfall () {
                    var columnHeight=[];
                    var waterFallWith = container.offsetWidth;
                    var n = parseInt(waterFallWith/boxWidth);
                    var columnNum = n == 0 ? 1 : n;
                    var baseLeft = wContainer.offsetLeft;
                    for (var i = 0,l=boxes.length; i <l ; i++) {
                        if (i<columnNum) {
                            columnHeight[i]=boxes[i].offsetHeight+margin;
                            boxes[i].style.top = 0;
                            boxes[i].style.left =  i*boxWidth+margin+'px';
                        } else{
                            var innsertColumn = minColunmnIndex(columnHeight),
                                imgHeight = boxes[i].offsetHeight+ margin;
                            boxes[i].style.top = columnHeight[innsertColumn]+'px';
                            boxes[i].style.left = innsertColumn*boxWidth+margin+'px';
                            columnHeight[innsertColumn] +=imgHeight; 
                        };
    
                    };
                };                
                
                var wf = {
                    master: container,
                    waterfall:waterfall
                }
                
                return wf;
            }
            var wf = new waterWall(document.getElementsByClassName("waterfall-container").item(0));
            window.onload = function(){wf.waterfall();};
            window.onresize = function(){
                wf.master.style.width = null;
                wf.waterfall();
            };
        
            
            document.getElementById("mediaSet").addEventListener("click",function(ev){
                var link  = ev.target,
                width = link.text;
                wf.master.style.width = width;
                wf.waterfall();
                
            },false);
            
        </script>
    </body>
    </html>
    复制代码

    分析:

    1. 核心就是waterfall方法,计算当前容器的offsetWith,和定义好的单位元素的宽度以及定义的margin来计算列数,再通过当前索引

    2. minColumnIndex来计算当前高度最小的列,然后取改列已经存有的高度作为top的值,用 index * 单位元素的宽度 + margin作为 left的值

    3.头部定义媒体查询,做到初始化的时候,自动调整,当然,在resize的时候可以动态重新计算,我这里没有这么做

    4. 设置了几个 1300,100, 900, 600几个值,用来点击测试。

    源码下载:

    http://files.cnblogs.com/files/mouse_in_beijing/PB.zip

  • 相关阅读:
    NOI Online 2020 提高组游记
    【HDU5840】This world need more Zhu
    CSP-S 2019 AFO记
    防错笔记
    关于Blog
    题解 【UER #6】逃跑
    动态规划杂题选记
    有趣计数题选做
    题解 [POI2012] Leveling Ground
    xioa han 带画家!
  • 原文地址:https://www.cnblogs.com/cloud-/p/6681000.html
Copyright © 2011-2022 走看看