国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

基于JavaScript實現瀑布流布局

2019-11-19 13:15:01
字體:
來源:轉載
供稿:網友

本文實例為大家分享了js實現瀑布流布局的具體代碼,供大家參考,具體內容如下

1、html+css+js代碼:

<!DOCTYPE html><html><head>  <meta http-equiv="Content-Type" content="text/html" charset="utf-8" />  <title>hhh</title></head><body>  <style type="text/css">    *{      padding: 0;      margin: 0;    }    #main{      position: relative;    }    .pin{      float: left;      padding: 15px 0 0 15px;    }    .box{      border-radius: 5px;      box-shadow: 0 0 6px #ccc;      border:1px solid #ccc;      padding: 10px;    }    .box img{      width: 162px;      height:auto;    }  </style><script type="text/javascript">  window.onload = function(){    waterfall("main","pin");    var dataint = {'data':[{'src':'1.jpg'},{'src':'2.jpg'},{'src':'3.jpg'},{'src':'4.jpg'}]};    window.onscroll = function(){      if (checkscrollside()) {        var oparent = document.getElementById('main');        for (var i = 0; i < dataint.data.length; i++) {          var opin = document.createElement('div');          opin.className = 'pin';          oparent.appendChild(opin);          var obox = document.createElement('div');          obox.className = 'box';          opin.appendChild(obox);          var oimg = document.createElement('img');          oimg.src = './images/' +dataint.data[i].src;          obox.appendChild(oimg);        }        waterfall('main','pin');      };    }  }  //parent為父元素的id,pin為子元素id  function waterfall(parent,pin){    var oparent = document.getElementById(parent);    var apin = getclassobj(oparent,pin);//獲取id為oparent的類名為pin的元素    var ipinw = apin[0].offsetWidth;    var num = Math.floor(document.documentElement.clientWidth/ipinw);    oparent.style.cssText = 'width:' + ipinw*num + 'px;margin:0 auto;';    var pinharr = [];    for( var i = 0;i < apin.length; i++)    {      var pinh = apin[i].offsetHeight;      if (i < num) {        pinharr[i] = pinh;      }      else{        var minh = Math.min.apply(null,pinharr);        var minhindex = getminhindex(pinharr,minh);        apin[i].style.position = 'absolute';        apin[i].style.top = minh +'px';        apin[i].style.left = apin[minhindex].offsetLeft + 'px';        pinharr[minhindex] += apin[i].offsetHeight;       }    }  }  //獲取id為parent的類名為classname的元素  function getclassobj(parent,classname){    var obj = parent.getElementsByTagName('*');    var pins = [];    for (var i = 0; i < obj.length; i++) {      if (obj[i].className == classname) {        pins.push(obj[i]);      }    };    return pins;  }  function getminhindex(arr,minh){    for(var i in arr){      if (arr[i] == minh) {        return i;      }    }  }  function checkscrollside(){    var oparent = document.getElementById('main');    var apin = getclassobj(oparent,'pin');    var lastpinh = apin[apin.length - 1].offsetTop + Math.floor(apin[apin.length - 1].offsetHeight/2);    var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;    var documenth = document.documentElement.clientHeight;    return(lastpinh<scrollTop + documenth)?true:false;  }</script></body>  <div id="main">    <div class="pin">      <div class="box">        <img src="images/0.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/1.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/2.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/3.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/4.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/5.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/6.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/7.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/8.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/9.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/10.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/11.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/12.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/13.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/14.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/15.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/16.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/17.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/18.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/19.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/20.jpg">      </div>    </div>    <div class="pin">      <div class="box">        <img src="images/21.jpg">      </div>    </div>  </div></html>

2、思路分析

首先做出靜態布局來。先計算出一行放多少個元素,然后再讓下一個元素放入第二行中,然后我們要計算出,放入第二行的第一個元素要放在哪個位置,故我們應該有一個數組用來存放每列的高度,當靜態的這些元素都放進去之后,可以更加完善,比如當拖動滾動條的時候,頁面刷新,更多元素填充,這里要用到json。

3、實現過程

1.初始的靜態頁面通過css來實現

2.靜態的瀑布流布局,先要獲取到父級對象main下面的所有類為pin的元素,然后計算一行中有幾個塊,此時用當前屏幕的寬度去除一個塊的寬度,得到num。然后用一個數組,用來存儲一行中每列的高度,通過循環,找出最小的高度,以及最小高度的下標值,然后用絕對定位設置高度。

3.當鼠標滾動的時候,通過一個函數來檢查是否需要加載新的圖片元素,這里用一個變量lastpinh計算出最后一個元素距離頂部的高度和自身高度的一半之和,當頁面的高度與滾動出去的高度之和大于最后一個的高度時,觸發事件,添加新的元素,以及調整布局。

4、需要掌握知識點:

json的數據存儲

window.onscroll();document.createElement();obj.className;obj.appendChild(obj1);obj.offsetWidth/offsetHeight/offsetLeft/offsetTop;document.documentElement.clientWidth/clientHeight;obj.style.cssTextMath.min.apply();Math.floor();obj.push();document.documentElement.scrollTopdocument.body.scrollTop;

注:這些都是我所不熟練的知識點。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 西乌| 嘉峪关市| 吉林市| 黄梅县| 张家口市| 尉犁县| 临高县| 江都市| 奎屯市| 漳州市| 浦北县| 天水市| 孟津县| 武隆县| 麻栗坡县| 普兰县| 泾阳县| 新龙县| 蒲江县| 洛宁县| 东阳市| 黄骅市| 奎屯市| 信宜市| 繁昌县| 库尔勒市| 翁牛特旗| 共和县| 汤原县| 盐津县| 兰西县| 昭通市| 聂荣县| 天柱县| 大悟县| 寿宁县| 海原县| 新田县| 盘锦市| 额济纳旗| 宜都市|