亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > 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;

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品www久久久| 国产免费一区二区三区在线观看| 日韩精品欧美国产精品忘忧草| 欧美国产日韩一区二区三区| 久久久国产精品免费| 久久男人av资源网站| 亚洲成人av片| 亚洲成人av在线| 亚洲成人久久一区| 欧美日本在线视频中文字字幕| 国产精品综合久久久| 日韩福利视频在线观看| 亚洲精品自拍第一页| 亚洲欧美激情在线视频| 国产精品揄拍500视频| 日韩免费不卡av| 久久人人爽人人| 久久成年人免费电影| 欧美视频一区二区三区…| 欧美性感美女h网站在线观看免费| 国产91精品久久久久久久| 日韩精品福利网站| 欧洲成人性视频| 久久久亚洲网站| 欧美性猛交xxxx| www.欧美视频| 国产精品偷伦一区二区| 亚洲国产精品va在线观看黑人| 久久精品视频va| 亚洲成人av中文字幕| 国产精品久在线观看| 久久人人看视频| 亚洲性生活视频在线观看| 欧美日韩国产一中文字不卡| 欧美黄色www| 久久久久久综合网天天| 久久69精品久久久久久久电影好| xxxx欧美18另类的高清| 日韩美女写真福利在线观看| 国产亚洲福利一区| 国产亚洲精品综合一区91| 日韩免费观看高清| 久久久久国产精品免费网站| 日韩中文在线不卡| 精品中文字幕久久久久久| 成人做爰www免费看视频网站| 97av在线视频免费播放| 中文字幕精品久久| 中文字幕精品一区二区精品| 欧美电影在线观看网站| 欧美刺激性大交免费视频| 亚洲国产精品系列| 久久久久久免费精品| 日韩视频在线免费| 91国产在线精品| 久久久久久久久91| 九色91av视频| 亚洲成人久久久久| 成人网在线视频| 欧美天天综合色影久久精品| 国产精自产拍久久久久久| 亚洲美女精品成人在线视频| 成人精品福利视频| 欧美激情aaaa| 国产欧美一区二区三区久久| 欧美在线播放视频| 亚洲精品视频网上网址在线观看| 久久午夜a级毛片| 国产精欧美一区二区三区| 国产91亚洲精品| 日本精品性网站在线观看| 色伦专区97中文字幕| 国产一区二区三区视频免费| 96pao国产成视频永久免费| 日韩美女福利视频| 国内精品久久久久久中文字幕| 国产在线视频一区| 日韩欧美综合在线视频| 欧美精品少妇videofree| 欧美理论电影在线观看| 欧美日韩色婷婷| 亚洲裸体xxxx| 北条麻妃一区二区三区中文字幕| 亚洲人成亚洲人成在线观看| 精品高清一区二区三区| 91国语精品自产拍在线观看性色| 萌白酱国产一区二区| 欧美wwwxxxx| 国产精品三级网站| 日韩精品丝袜在线| 亚洲色图17p| 亲爱的老师9免费观看全集电视剧| 欧美精品国产精品日韩精品| 久久人人爽人人爽人人片av高请| 亚洲国产天堂久久国产91| 国产精品第2页| 亚洲精品av在线播放| 7777精品久久久久久| 欧美激情极品视频| 亚洲成人精品久久| 欧美激情喷水视频| 国产精品人人做人人爽| 国产一区二区三区在线观看视频| 成人女保姆的销魂服务| 久久久天堂国产精品女人| 日本免费久久高清视频| 亚洲欧美激情四射在线日| 亚洲bt天天射| 色噜噜久久综合伊人一本| 日韩欧美在线看| 亚洲国产毛片完整版| 国产日韩专区在线| 日韩在线视频观看正片免费网站| 中文字幕在线国产精品| 国产成人精品国内自产拍免费看| 精品一区二区三区电影| 国产精品久久久久久久久久| 蜜臀久久99精品久久久无需会员| 精品美女国产在线| www.久久久久久.com| 欧美第一黄色网| 欧美重口另类videos人妖| 亚洲女人天堂成人av在线| 中文字幕最新精品| 国产日韩欧美电影在线观看| 亚洲国产一区二区三区在线观看| 亚洲第一免费播放区| 91亚洲精品久久久| 成人亚洲综合色就1024| 色老头一区二区三区在线观看| 日韩欧美精品网站| 欧美一级片在线播放| 亚洲国产精品va| 欧美日韩在线视频一区二区| 色综合伊人色综合网站| 国产精品久久久久久久久久| 丰满岳妇乱一区二区三区| 色伦专区97中文字幕| 亚洲人午夜色婷婷| 久久精品2019中文字幕| 欧美日韩国产区| 成人av番号网| 日韩av色在线| 日韩av在线导航| 国产精品视频资源| 亚洲人a成www在线影院| 日本伊人精品一区二区三区介绍| 北条麻妃一区二区在线观看| 国产成人精品综合久久久| 久久91精品国产| 粉嫩老牛aⅴ一区二区三区| 日韩精品在线私人| 亚洲第一网站男人都懂| 国产日韩视频在线观看| 亚洲国产精品久久久| 欧美亚州一区二区三区| 中文字幕在线亚洲| 欧美成人合集magnet| 久久精品小视频| 欧美大片欧美激情性色a∨久久| 精品美女永久免费视频| 琪琪第一精品导航| 92看片淫黄大片欧美看国产片| 国产91热爆ts人妖在线|