欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生js實(shí)現(xiàn)瀑布流布局

 更新時(shí)間:2017年03月08日 10:01:59   作者:Vampire-blog  
這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)瀑布流布局的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

用js實(shí)現(xiàn)瀑布流布局以及通過模擬的數(shù)據(jù)加載圖片,已標(biāo)記注釋

效果如圖:

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>瀑布流布局-JS實(shí)現(xiàn)</title>
</head>
<style type="text/css">
  *{
    margin: 0;
    padding: 0;
  }
  #main{
    position: relative;/*整體相對(duì)定位,因?yàn)槊總€(gè)小圖片盒子的位置是通過計(jì)算再由絕對(duì)定位放置,是需要相對(duì)于main盒子*/
  }
  .box{
    padding: 15px 0 0 15px;/*padding為內(nèi)邊距,后面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');//調(diào)用瀑布布局的函數(shù)
    var dataInt={"data":[{"src":'23.jpg'},{"src":'24.jpg'},{"src":'25.jpg'}]}//模擬出要加載的圖片
    window.onscroll=function(){
      if(checkscrollSlide()){//如果調(diào)用函數(shù)的返回結(jié)果為true
        //將數(shù)據(jù)塊渲染到當(dāng)前頁面底部
        for(var i=0;i<dataInt.data.length;i++){//dataInt對(duì)象的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;//計(jì)算每個(gè)box的寬度
      //計(jì)算整個(gè)頁面顯示的列數(shù)(頁面寬/box的寬)
      var cols=Math.floor(document.documentElement.clientWidth/oBoxW);
      //設(shè)置main的寬,居中
      oParent.style.cssText='width:'+oBoxW*cols+'px;margin:0 auto;';
      var hArr=[];//存放每一列高度的數(shù)組
      for(var i=0;i<oBoxs.length;i++){
        if(i<cols){
          hArr.push(oBoxs[i].offsetHeight);//將第一行的各個(gè)高度加到數(shù)組中
        }else{
          var minH=Math.min.apply(null,hArr);//apply方法可以改變數(shù)組的指向,因?yàn)镸ath.min方法不支持?jǐn)?shù)組
          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;
        }

      }
    }
    //檢測(cè)是否具備了滾動(dòng)條加載數(shù)據(jù)塊的條件
    function checkscrollSlide(){
      //最后一個(gè)盒子的距頂部的高度加上自身高度的一半
      var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+ Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2);
      //頁面滾走的距離
      var scrollTop=document.body.scrollTop||document.documentElement.scrollTop;
      //當(dāng)前瀏覽器窗口可視區(qū)域高度
      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>

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Javascript 獲取LI里的內(nèi)容

    Javascript 獲取LI里的內(nèi)容

    使用Javascript(簡稱JS)取得LI里的內(nèi)容(簡單易懂的代碼實(shí)例)
    2008-12-12
  • PixiJS學(xué)習(xí)之常見圖形的繪制詳解

    PixiJS學(xué)習(xí)之常見圖形的繪制詳解

    pixijs 是一個(gè)強(qiáng)大的 Web Canvas 2D 庫,以其強(qiáng)大性能而著稱。這篇文章主要帶大家學(xué)習(xí)一下PixiJS是如何實(shí)現(xiàn)常見圖形繪制的,希望對(duì)大家有所幫助
    2023-02-02
  • 常用DOM整理

    常用DOM整理

    js在操作DOM中存在著許多跨瀏覽器方面的坑,本文花了我將近一周的時(shí)間整理,我將根據(jù)實(shí)例整理那些大大小小的“坑”。
    2015-06-06
  • 精通Javascript系列之Javascript基礎(chǔ)篇

    精通Javascript系列之Javascript基礎(chǔ)篇

    javascrpit的基本概念分析,剛開始學(xué)習(xí)js的朋友可以參考下。
    2011-06-06
  • functional繼承模式 摘自javascript:the good parts

    functional繼承模式 摘自javascript:the good parts

    javascript:the good parts 書中Inheritance部分講到了一種functional的繼承方式, 具體這個(gè)functional該如何翻譯,就不是很清楚了, 就直接意會(huì)一下吧
    2011-06-06
  • js尾調(diào)用優(yōu)化的實(shí)現(xiàn)

    js尾調(diào)用優(yōu)化的實(shí)現(xiàn)

    這篇文章主要介紹了js尾調(diào)用優(yōu)化的實(shí)現(xiàn),尾調(diào)用(Tail Call)是函數(shù)式編程的一個(gè)重要概念,本文介紹它的含義和用法。感興趣的可以了解一下
    2019-05-05
  • nuxt+axios實(shí)現(xiàn)打包后動(dòng)態(tài)修改請(qǐng)求地址的方法

    nuxt+axios實(shí)現(xiàn)打包后動(dòng)態(tài)修改請(qǐng)求地址的方法

    這篇文章主要介紹了nuxt+axios實(shí)現(xiàn)打包后動(dòng)態(tài)修改請(qǐng)求地址的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • bootstrap table配置參數(shù)例子

    bootstrap table配置參數(shù)例子

    這篇文章主要為大家詳細(xì)介紹了bootstrapTable的參數(shù)設(shè)置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • JS中不應(yīng)該使用箭頭函數(shù)的四種情況詳解

    JS中不應(yīng)該使用箭頭函數(shù)的四種情況詳解

    箭頭函數(shù)給我們的工作帶來了極大的方便,但是它們有什么缺點(diǎn)呢?我們應(yīng)該一直使用箭頭函數(shù)嗎?我們應(yīng)該在哪些場景中停止使用箭頭函數(shù)?本文就來為大家詳細(xì)講講
    2022-07-07
  • 詳解小程序開發(fā)經(jīng)驗(yàn):多頁面數(shù)據(jù)同步

    詳解小程序開發(fā)經(jīng)驗(yàn):多頁面數(shù)據(jù)同步

    這篇文章主要介紹了小程序開發(fā)經(jīng)驗(yàn):多頁面數(shù)據(jù)同步,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05

最新評(píng)論