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

首頁 > 編程 > JavaScript > 正文

原生js實現瀑布流布局

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

用js實現瀑布流布局以及通過模擬的數據加載圖片,已標記注釋

效果如圖:

<!DOCTYPE html><html><head lang="en">  <meta charset="UTF-8">  <title>瀑布流布局-JS實現</title></head><style type="text/css">  *{    margin: 0;    padding: 0;  }  #main{    position: relative;/*整體相對定位,因為每個小圖片盒子的位置是通過計算再由絕對定位放置,是需要相對于main盒子*/  }  .box{    padding: 15px 0 0 15px;/*padding為內邊距,后面js獲取的高度包括padding的距離*/    float: left;  }  .pic{    padding: 10px;    border: 1px solid #ccc;    border-radius: 5px;    box-shadow: 0 0 5px #ccc;  }  .pic img{    width: 165px;    height: auto;  }</style><script type="text/javascript">  window.onload=function(){    var oParent=document.getElementById("main");    var oBoxs=oParent.getElementsByClassName("box");    waterfall('main','box');//調用瀑布布局的函數    var dataInt={"data":[{"src":'23.jpg'},{"src":'24.jpg'},{"src":'25.jpg'}]}//模擬出要加載的圖片    window.onscroll=function(){      if(checkscrollSlide()){//如果調用函數的返回結果為true        //將數據塊渲染到當前頁面底部        for(var i=0;i<dataInt.data.length;i++){//dataInt對象的data屬性的長度          var oBox=document.createElement('div');          oBox.className='box';          oParent.appendChild(oBox);//添加到父元素的最后          var oPic=document.createElement('div');          oPic.className='pic';          oBox.appendChild(oPic);          var oImg=document.createElement('img');          oImg.src="img/"+dataInt.data[i].src;          oPic.appendChild(oImg);        }        waterfall('main','box');      };    }    function waterfall(parent,box){      var oParent=document.getElementById(parent);      var oBoxs=oParent.getElementsByClassName(box);      var oBoxW=oBoxs[0].offsetWidth;//計算每個box的寬度      //計算整個頁面顯示的列數(頁面寬/box的寬)      var cols=Math.floor(document.documentElement.clientWidth/oBoxW);      //設置main的寬,居中      oParent.style.cssText='width:'+oBoxW*cols+'px;margin:0 auto;';      var hArr=[];//存放每一列高度的數組      for(var i=0;i<oBoxs.length;i++){        if(i<cols){          hArr.push(oBoxs[i].offsetHeight);//將第一行的各個高度加到數組中        }else{          var minH=Math.min.apply(null,hArr);//apply方法可以改變數組的指向,因為Math.min方法不支持數組          var index=getMinhIndex(hArr,minH);          oBoxs[i].style.position='absolute';          oBoxs[i].style.top=minH+'px';          oBoxs[i].style.left=oBoxs[index].offsetLeft+'px';          hArr[index]+=oBoxs[i].offsetHeight;        }      }    }    function getMinhIndex(arr,val){      for(var i in arr){        if(arr[i]==val){          return i;        }      }    }    //檢測是否具備了滾動條加載數據塊的條件    function checkscrollSlide(){      //最后一個盒子的距頂部的高度加上自身高度的一半      var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+ Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2);      //頁面滾走的距離      var scrollTop=document.body.scrollTop||document.documentElement.scrollTop;      //當前瀏覽器窗口可視區域高度      var height=document.body.clientHeight||document.documentElement.clientHeight;      return (lastBoxH<scrollTop+height) ? true : false;    }}</script><body><div id="main">  <div class="box">  <div class="pic">    <img src="img/0.jpg" />  </div></div>  <div class="box">    <div class="pic">      <img src="img/1.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/2.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/3.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/4.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/5.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/6.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/7.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/8.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/9.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/10.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/11.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/12.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/13.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/14.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/15.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/16.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/17.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/18.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/19.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/20.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/21.jpg" />    </div>  </div>  <div class="box">    <div class="pic">      <img src="img/22.jpg" />    </div>  </div></div></body></html>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 陇西县| 静宁县| 遵义县| 五常市| 嘉定区| 遂溪县| 绍兴县| 敦化市| 承德市| 平远县| 临泽县| 修文县| 娱乐| 佛坪县| 盱眙县| 浮梁县| 茶陵县| 九江市| 道真| 察隅县| 华亭县| 庐江县| 沧源| 宜君县| 东光县| 攀枝花市| 安徽省| 资兴市| 兴城市| 大邑县| 理塘县| 吉木乃县| 渭源县| 兴仁县| 齐河县| 佛冈县| 潜山县| 吴忠市| 安多县| 吉林市| 东乡县|