jQuery實現瀑布流的簡單方法

來源:互聯網
上載者:User

標籤:style   blog   color   width   os   cti   

HTML代碼

<!doctype html><html lang="en"><head>    <meta charset="UTF-8">    <title>waterFall</title>    <link rel="stylesheet" href="wf.css">    <script src="jquery.js"></script>    <script src="wf.js"></script></head><body>        <div class="wrap">        <div class="box">            <img src="1.jpg" alt="">            <p>11111111111</p>        </div>        <div class="box">            <img src="2.jpg" alt="">            <p>22222222222</p>        </div>        <div class="box">            <img src="3.jpg" alt="">            <p>33333333333</p>        </div>        <div class="box">            <img src="4.jpg" alt="">            <p>44444444444</p>        </div>        <div class="box">            <img src="5.jpg" alt="">            <p>555555555555</p>        </div>        <div class="box">            <img src="6.jpg" alt="">            <p>666666666666</p>        </div>        <div class="box">            <img src="7.jpg" alt="">            <p>777777777777</p>        </div>        <div class="box">            <img src="8.jpg" alt="">            <p>8888888888888</p>        </div>        <div class="box">            <img src="9.jpg" alt="">            <p>99999999999</p>        </div>    </div></body></html>

js代碼

$(function(){    $(‘img‘).load(function(){        var box = $(‘.box‘);        var boxHeight = {            leftBox:[],            centerBox:[],            rightBox:[]        }        for(var i = 0;i < box.length;i++){        var now = i%3;    //now的值為0,1,2            switch(now){                case 0:                    box.eq(i).css(‘left‘,‘10px‘);                    boxHeight.leftBox.push(box.eq(i).height());                    var now2 = Math.floor(i/3);                    if(now2==0){                        box.eq(i).css(‘top‘,‘0‘);                    }else{                        var total = 0;                        for(var j=0;j<now2;j++){                            total += boxHeight.leftBox[j]+10;                        }                        box.eq(i).css(‘top‘,total+‘px‘);                    }                break;                case 1:                    box.eq(i).css(‘left‘,‘270px‘);                    boxHeight.centerBox.push(box.eq(i).height());                    var now2 = Math.floor(i/3);                    if(now2==0){                        box.eq(i).css(‘top‘,‘0‘);                    }else{                        var total = 0;                        for(var j=0;j<now2;j++){                            total += boxHeight.centerBox[j]+10;                        }                        box.eq(i).css(‘top‘,total+‘px‘);                    }                break;                case 2:                    box.eq(i).css(‘left‘,‘530px‘);                    boxHeight.rightBox.push(box.eq(i).height());                    var now2 = Math.floor(i/3);                    if(now2==0){                        box.eq(i).css(‘top‘,‘0‘);                    }else{                        var total = 0;                        for(var j=0;j<now2;j++){                            total += boxHeight.rightBox[j]+10;                        }                        box.eq(i).css(‘top‘,total+‘px‘);                    }                break;            }        }    });});

CSS代碼

*{    padding: 0;    margin: 0;}.wrap{    position: relative;}.box{    position: absolute;    left: 0;    top:0;    width: 250px;}.box img{width: 250px;}

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.