瀑布流布局淺析

最近做手機端項目使用到瀑布流布局,所以在這邊總結(jié)下實現(xiàn)瀑布流布局的幾種方法品姓。

1寝并、使用插件(Wookmark.js)
這個網(wǎng)上一搜一大把箫措,把這個方法的應用總結(jié)下。有很多博客可以參考下:博客1衬潦、博客2斤蔓。使用該插件容器(myContent)的定位必須是相對定位

       //html
     <div id="myContent">
      <div class="item"></div>......
    </div>
    //第一種使用方式
   $('.item').wookmark();
    //第二種使用方式
    $('.item').wookmark({
      container: $('#myContent'),
      offset: 0,
      itemWidth: 196,
      autoResize: true
  });
  //第三種使用方式
  $(function(){
    $(window).load(function(){
      $("#myContent").wookmark();
    });
  })

跟ajax結(jié)合使用

    var handler = null;
    $(function(){
       //綁定滾動事件
      $(document).bind('scroll', onScroll);
      $(window).load(function(){
        handler=$("#myContent");
        handler.wookmark();
      });
  })

//定義滾動函數(shù)
function onScroll(event) {
//是否到底部(這里是判斷離底部還有100px開始載入數(shù)據(jù)).
var closeToBottom = ($(window).scrollTop() + $(window).height() > $(document).height() - 100);
if(closeToBottom) {
    $.ajax({url:"",async: false, dataType:"html", success:function(data){
        $('#myContent').append(data);
        //清除原來的定位
        if (handler.wookmarkInstance) {
          handler.wookmarkInstance.clear();
        }
        // //創(chuàng)建新的wookmark對象
        handler = $('#myContent');
        handler.wookmark();
        }
    });
    }
 };

2、使用css3
這種方式簡單易于理解别渔,但是布局比較難調(diào)整附迷,可能會將div拆分顯示。如果考慮到兼容性問題哎媚,就不推薦這種方式喇伯。

  <style>
   #myContent {
 padding-left:100px;
    -webkit-column-count: 5; 
   /* -webkit-column-gap: -20px;*/
   /* -webkit-column-rule: 5px solid #333;*/
   /* -webkit-column-width: 200px;*/

    -moz-column-count: 5;
   /* -moz-column-gap: -20px;*/
   /* -moz-column-rule: 5px solid #333;*/
  /*  -moz-column-width: 200px;*/

    column-count: 5;
    /*column-gap: -20px;*/
   /* column-rule: 5px solid #333;*/
   /* column-width: 200px;*/
}

.item{
    float:left;
}

</style>

  //html
  <div id="myContent">
    <div class="item"></div>......
</div>

3、使用float
這種方法也是比較簡單的實現(xiàn)方法拨与,但是靈活性太差

  <style>
#myContent{
    margin:0 auto;
    width:880px;
}
.item{
float:left;
    
}
  </style>

  <div id="myContent">
    <div class="item">
      <div class="item1"></div>.....
    </div>
    <div class="item">
      <div class="item1"></div>.....
    </div>
    <div class="item">
      <div class="item1"></div>.....
    </div>
  </div>

4稻据、使用絕對定位+jquery方式

原理跟使用Wookmark.js類似,容器使用相對定位买喧,子元素使用絕對定位捻悯,然后通過jquery計算每個元素的高度進行元素的排列。

  var margin = 10;//這里設置間距
  var li=$("li");//這里是區(qū)塊名稱
  var   li_W = li[0].offsetWidth+margin;//取區(qū)塊的實際寬度
function liuxiaofan(){//定義成函數(shù)便于調(diào)用
var h=[];//記錄區(qū)塊高度的數(shù)組
var n = document.documentElement.offsetWidth/li_W|0;//窗口的寬度除以區(qū)塊寬度就是一行能放幾個區(qū)塊
for(var i = 0;i < li.length;i++) {//有多少個li就循環(huán)多少次
    li_H = li[i].offsetHeight;//獲取每個li的高度
    if(i < n) {//n是一行最多的li淤毛,所以小于n就是第一行了
        h[i]=li_H;//把每個li放到數(shù)組里面
        li.eq(i).css("top",0);//第一行的Li的top值為0
        li.eq(i).css("left",i * li_W);//第i個li的左坐標就是i*li的寬度
        }
    else{
        min_H =Math.min.apply(null,h) ;//取得數(shù)組中的最小值今缚,區(qū)塊中高度值最小的那個
        minKey = getarraykey(h, min_H);//最小的值對應的指針
        h[minKey] += li_H+margin ;//加上新高度后更新高度值
        li.eq(i).css("top",min_H+margin);//先得到高度最小的Li,然后把接下來的li放到它的下面
        li.eq(i).css("left",minKey * li_W); //第i個li的左坐標就是i*li的寬度
    }
    $("h3").eq(i).text("編號:"+i+"低淡,高度:"+li_H);//把區(qū)塊的序號和它的高度值寫入對應的區(qū)塊H3標題里面
}
  }
  /* 使用for in運算返回數(shù)組中某一值的對應項數(shù)(比如算出最小的高度值是數(shù)組里面的第幾個) */
  function getarraykey(s, v) {for(k in s) {if(s[k] == v) {return k;}}}
  /*這里一定要用onload姓言,因為圖片不加載完就不知道高度值*/
  window.onload = function() {liuxiaofan();};
/*瀏覽器窗口改變時也運行函數(shù)*/
window.onresize = function() {liuxiaofan();};
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蔗蹋,隨后出現(xiàn)的幾起案子何荚,更是在濱河造成了極大的恐慌,老刑警劉巖猪杭,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件餐塘,死亡現(xiàn)場離奇詭異,居然都是意外死亡皂吮,警方通過查閱死者的電腦和手機戒傻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涮较,“玉大人稠鼻,你說我怎么就攤上這事】衿保” “怎么了候齿?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我慌盯,道長周霉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任亚皂,我火速辦了婚禮俱箱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘灭必。我一直安慰自己狞谱,他們只是感情好,可當我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布禁漓。 她就那樣靜靜地躺著跟衅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪播歼。 梳的紋絲不亂的頭發(fā)上伶跷,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天,我揣著相機與錄音秘狞,去河邊找鬼叭莫。 笑死,一個胖子當著我的面吹牛烁试,可吹牛的內(nèi)容都是我干的雇初。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼减响,長吁一口氣:“原來是場噩夢啊……” “哼抵皱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起辩蛋,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎移盆,沒想到半個月后悼院,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡咒循,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年据途,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叙甸。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡颖医,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出裆蒸,到底是詐尸還是另有隱情熔萧,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站佛致,受9級特大地震影響贮缕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜俺榆,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一感昼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧罐脊,春花似錦定嗓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至梗夸,卻和暖如春层玲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背反症。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工辛块, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人铅碍。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓润绵,卻偏偏與公主長得像,于是被迫代替她去往敵國和親胞谈。 傳聞我的和親對象是個殘疾皇子尘盼,可洞房花燭夜當晚...
    茶點故事閱讀 44,592評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,748評論 1 92
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,072評論 25 707
  • 這一章主要是讓大家了解一下烦绳,集成環(huán)信會一步一步給大家講解卿捎,最近項目比較忙,沒時間跟新簡書径密。大家見諒午阵。 首先...
    mayChunJ閱讀 266評論 0 0
  • “我很害怕底桂。有時候,我還是很不正常惧眠∽雅常” “有時候,我們都有那么一點點不正常氛魁。還記得嗎暮顺,那時候我爸媽離婚了厅篓,我一整個...
    小薇子閱讀 540評論 0 1
  • 170809【讀書 day150】《我決定活得有趣》蔡瀾 35m 摘抄—— 1、 人生生的樂趣拖云,從一點點小的罪惡開...
    水若_小水囈夢閱讀 201評論 0 1