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

首頁 > 編程 > JavaScript > 正文

基于JavaScript實現瀑布流布局(二)

2019-11-20 10:41:14
字體:
來源:轉載
供稿:網友

本文實例講解了JavaScript實現瀑布流布局詳細代碼,分享給大家供大家參考,具體內容如下

1.建立Html模版

想法是先用一個div container承載所有內容,然后div box用來放置圖片,最后div box_border來當圖片框,代碼如下

<!DOCTYPE html><html><head>  <meta charset="UTF-8">  <title>瀑布流</title></head><body>  <div class="container" id="container">    <div class="box_border" id="box_border">      <div class="box" id="box1">        <img src="image/01.jpg">      </div>  <!--把Box復制多份,這里因為代碼重復省略了-->    </div>  </div></body></html>

2.通過css簡單設置樣式

主要設置水平放置,相框顏色,邊界之類的

/*邊界不留空,背景黑灰*/body{  margin: 0px;  background: darkgray;}/*總布局設置為相對布局*/.container{  position: relative;}/*設置box屬性*/.box{  padding: 5px;  float: left;}/*設置圖片邊框陰影和圓角*/.box_border{  padding: 5px;  border: 1px solid #cccccc;  box-shadow: 0px 0px 5px #ccc;  border-radius: 5px;}/*設置圖片格式*/.box_border img{  width: 150px;  height: auto;}

3.JS控制每一行所擺放的圖片個數

上面的css布局之后,瀏覽器窗口大小改變,里面的圖片數量也會改變,現在要用JS固定住每一行的圖片數量,對于不同尺寸的屏幕都能做到很好的效果

/* 用于加載其他函數 */window.onload = function(){  setImgLocation("container");}/* 設置圖片個數 */function setImgLocation(parent){  var cparent = document.getElementById(parent);//得到父節點  var childArray = getChildNodes(cparent);//得到圖片數量  var imgWidth = childArray[0].offsetWidth;//獲取照片寬度  var screenWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度  var count = Math.floor(screenWidth/imgWidth);//每行的個數  cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中}/* 獲取全部圖片的個數 */function getChildNodes(parent){  var childArray =[];//定義一個數組存放圖片box  var tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點  //循環添加class為box的節點  for(var i = 0;i<tempNodes.length;i++){    if(tempNodes[i].className == "box"){      childArray.push(tempNodes[i]);    }  }  return childArray;//返回所有的子節點}注意:針對不同屏幕大小顯示的個數是不一樣的 

4.JS實現靜態瀑布流

先實現靜態的布局,也就是瀏覽器下拉不會自動刷新出新的圖片.
實現排列算法很簡單

  • 1.把第一排圖片的高度全部存到一個數組
  • 2.計算出第一排中的圖片的最小高度和對應位置
  • 3.把第一排之后的第一個圖片放到該位置上
  • 4.重新設置該位置的高度為兩個圖片相加
  • 5.循環2剩余全部圖片

代碼:

/* 用于加載其他函數 */window.onload = function(){  setImgLocation("container");}/* 設置圖片個數及位置排列 */function setImgLocation(parent){  var cparent = document.getElementById(parent);//得到父節點  var childArray = getChildNodes(cparent);//得到圖片數量  var imgWidth = childArray[0].offsetWidth;//獲取照片寬度  var screenWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度  var count = Math.floor(screenWidth/imgWidth);//每行的個數  cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中  //定義數組,存放第一行照片高度  var imgHArray = [];  //循環遍歷圖片  for(var i=0;i<childArray.length;i++){    //如果圖片在第一行則獲取高度    if(i<count){      imgHArray[i] = childArray[i].offsetHeight;    }else//否則把最小高度的填充剩余圖片    {      var minHeight = Math.min.apply(null,imgHArray);//獲取最小高度      var minIndex = getMinIndex(minHeight,imgHArray);//獲取最小高度對應的下標      childArray[i].style.position = "absolute";//設置要填充的圖片盒子為絕對布局,否則不能更換位置      childArray[i].style.top = minHeight+"px";//設置要填充圖片距頂高度      childArray[i].style.left = childArray[minIndex].offsetLeft+"px";//設置要填充圖片距左高度      imgHArray[minIndex] += childArray[i].offsetHeight;//填充后把當前位置高度設為兩個圖片相加      //開始下一輪循環    }  }}/* 獲取最小高度對應的下標 */function getMinIndex(minHeight,imgHArray){  for(var i in imgHArray){    if(imgHArray[i] == minHeight){      return i;    }  }}/* 獲取全部圖片的個數 */function getChildNodes(parent){  var childArray =[];//定義一個數組存放圖片box  var tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點  //循環添加class為box的節點  for(var i = 0;i<tempNodes.length;i++){    if(tempNodes[i].className == "box"){      childArray.push(tempNodes[i]);    }  }  return childArray;//返回所有的子節點}

5.js實現動態加載

動態加載也就是滾動條永遠滑不到底部,要解決動態加載我們需要考慮兩個問題:
1).什么時候加載?
滑動距離+瀏覽器高度>最后一張圖片距離頂部的距離
2).怎樣加載?
通過創建新的節點,把創建的節點添加進去即可
最終代碼:

/* 用于加載其他函數 */window.onload = function() {  var cparent = document.getElementById("container");//得到父節點  setImgLocation(cparent);  //設置加載的圖片  var data = ["image/01.jpg", "image/02.jpg", "image/03.jpg", "image/04.jpg", "image/05.jpg", "image/06.jpg", "image/07.jpg", "image/08.jpg", "image/09.jpg",    "image/11.jpg", "image/12.jpg", "image/13.jpg", "image/14.jpg", "image/15.jpg", "image/16.jpg", "image/17.jpg"];  //滑動監聽  window.onscroll = function () {    if (checkLoad(cparent)) {      for (var i = 0; i < data.length; i++) {        //創建新的節點        var div1 = document.createElement("div");        div1.className = "box";        var div2 = document.createElement("div");        div2.className = "box_border";        var img = document.createElement("img");        img.className = ".box_border img";        img.src = data[i];        div2.appendChild(img);        div1.appendChild(div2);        cparent.appendChild(div1);      }      setImgLocation(cparent);//創建節點后重新排列    }  }}/*檢查是否應該加載 */function checkLoad(cparent){  var childArray = getChildNodes(cparent);//得到圖片個數  var lastImgHight = childArray[childArray.length-1].offsetTop;//得到最后一張圖片距離頂部高度  var scrollHeight = document.documentElement.scrollTop||document.body.scrollTop;//獲得滑動距離(瀏覽器兼容性真煩人)  var browserHeight = document.documentElement.clientHeight;//獲得瀏覽器高度  if(lastImgHight < scrollHeight+browserHeight){//判斷是否加載    return true;  }else {    return false;  }}/* 設置圖片個數及位置排列 */function setImgLocation(cparent){  var childArray = getChildNodes(cparent);//得到圖片數量  var imgWidth = childArray[0].offsetWidth;//獲取照片寬度  var browserWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度  var count = Math.floor(browserWidth/imgWidth);//每行的個數  cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中  //定義數組,存放第一行照片高度  var imgHArray = [];  //循環遍歷圖片  for(var i=0;i<childArray.length;i++){    //如果圖片在第一行則獲取高度    if(i<count){      imgHArray[i] = childArray[i].offsetHeight;    }else//否則把最小高度的填充剩余圖片    {      var minHeight = Math.min.apply(null,imgHArray);//獲取最小高度      var minIndex = getMinIndex(minHeight,imgHArray);//獲取最小高度對應的下標      childArray[i].style.position = "absolute";//設置要填充的圖片盒子為絕對布局,否則不能更換位置      childArray[i].style.top = minHeight+"px";//設置要填充圖片距頂高度      childArray[i].style.left = childArray[minIndex].offsetLeft+"px";//設置要填充圖片距左高度      imgHArray[minIndex] += childArray[i].offsetHeight;//填充后把當前位置高度設為兩個圖片相加      //開始下一輪循環    }  }}/* 獲取最小高度對應的下標 */function getMinIndex(minHeight,imgHArray){  for(var i in imgHArray){    if(imgHArray[i] == minHeight){      return i;    }  }}/* 獲取全部圖片的個數 */function getChildNodes(parent){  var childArray =[];//定義一個數組存放圖片box  var tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點  //循環添加class為box的節點  for(var i = 0;i<tempNodes.length;i++){    if(tempNodes[i].className == "box"){      childArray.push(tempNodes[i]);    }  }  return childArray;//返回所有的子節點}

希望本文所述對大家學習javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲社区在线观看| 久久精品电影网| 亚洲精品欧美日韩专区| 亚洲欧美另类人妖| 久久久久国色av免费观看性色| 九九久久国产精品| 欧美电影免费观看网站| 福利视频第一区| 欧美高清自拍一区| 久久久久久久电影一区| 亚洲国产一区二区三区在线观看| 亚洲色图13p| 亚洲石原莉奈一区二区在线观看| 欧美日韩国产va另类| 色综合男人天堂| 欧美最近摘花xxxx摘花| 国内伊人久久久久久网站视频| 欧美色播在线播放| 欧美日韩美女视频| 亚洲另类欧美自拍| 中文欧美在线视频| 亚洲国产成人久久综合| 性色av一区二区三区免费| 国产午夜精品视频| 成人字幕网zmw| 亚洲a成v人在线观看| 亚洲欧美成人网| 中文字幕亚洲欧美日韩2019| 亚洲精品在线看| 国产精品国内视频| 91网站在线免费观看| 热久久这里只有精品| 亚洲精品一区二区久| 最好看的2019的中文字幕视频| 久久久久亚洲精品成人网小说| 久久黄色av网站| 欧美日韩成人网| 黑人狂躁日本妞一区二区三区| 午夜精品免费视频| 欧美精品久久久久久久久久| 日韩暖暖在线视频| 日韩中文字幕在线观看| 久久全国免费视频| 欧美日韩国产中文精品字幕自在自线| 精品在线小视频| 热久久美女精品天天吊色| 亚洲国产99精品国自产| 久久久久久久久久av| 尤物yw午夜国产精品视频明星| 91成人国产在线观看| 川上优av一区二区线观看| 欧美亚洲激情在线| 国产成人啪精品视频免费网| 日本一区二区三区在线播放| 午夜精品久久久久久99热| 最近2019年中文视频免费在线观看| 欧美成人中文字幕在线| 国产日韩欧美黄色| 欧美亚洲国产日本| 91精品国产777在线观看| 欧美成人精品三级在线观看| 久久97精品久久久久久久不卡| 亚洲欧美国产精品va在线观看| 欧美激情国产精品| 日韩精品中文字幕在线观看| 国产欧美久久久久久| 亚洲视频电影图片偷拍一区| www.亚洲一二| 精品亚洲永久免费精品| 91av视频导航| 国产精品日韩精品| 在线播放精品一区二区三区| 国产精品久久久久久久久久东京| 国产精品中文在线| 91久久久亚洲精品| 亚洲视频精品在线| 午夜免费日韩视频| www.亚洲免费视频| 亚洲欧洲第一视频| 欧美韩国理论所午夜片917电影| 久久精品小视频| 亚洲福利在线看| 国产精品成人免费电影| 神马国产精品影院av| 在线成人激情视频| 欧美成人精品三级在线观看| 亚洲午夜性刺激影院| 日本久久久a级免费| 亚洲一区二区三区毛片| 国产视频精品一区二区三区| 在线丨暗呦小u女国产精品| 欧美性猛交xxxx黑人猛交| 国产日韩欧美视频| 亚洲aaa激情| 成人国产精品免费视频| 日韩在线播放视频| 欧美日韩国产影院| 国产成人在线精品| 欧美激情va永久在线播放| 麻豆一区二区在线观看| 欧美亚洲成人精品| 超碰精品一区二区三区乱码| 奇米成人av国产一区二区三区| 亚洲大胆人体av| 亚洲成色www8888| 精品成人国产在线观看男人呻吟| 精品偷拍一区二区三区在线看| 国产在线98福利播放视频| 热99精品里视频精品| 久热在线中文字幕色999舞| 在线观看中文字幕亚洲| 欧美专区国产专区| 国产精品欧美激情在线播放| 国产精品网站大全| 国产精品中文久久久久久久| 国产免费一区视频观看免费| 日韩av大片在线| 成人在线精品视频| 亚洲另类xxxx| 中文字幕久精品免费视频| 欧美激情一区二区三区在线视频观看| 亚洲va男人天堂| 亚洲精品中文字幕av| 日韩av影院在线观看| 国产欧美一区二区三区视频| 国产精品自拍视频| 成人免费视频网| 久久免费少妇高潮久久精品99| 亚洲欧美日韩中文视频| 国产成人一区二区三区电影| 亚洲91精品在线| 91成人国产在线观看| 亚洲精选在线观看| 色www亚洲国产张柏芝| 亚洲iv一区二区三区| 精品国产精品自拍| 91久久精品国产91性色| 亚洲国产精彩中文乱码av| 精品国产老师黑色丝袜高跟鞋| 欧美性猛交xxxx免费看| 岛国视频午夜一区免费在线观看| 欧美在线亚洲一区| 亚洲伊人久久大香线蕉av| 国产欧美精品日韩精品| 在线视频日本亚洲性| 亚洲第一区中文字幕| 欧美一区二区三区……| 久久精品亚洲国产| 国产综合香蕉五月婷在线| 欧美黑人xxxx| 欧美性xxxxx| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美午夜精品久久久久久久| 欧美激情亚洲激情| 日韩福利视频在线观看| 中文字幕日韩电影| 亚洲一区精品电影| 日韩毛片在线观看| 欧美在线免费观看| 色综合亚洲精品激情狠狠| 久久99久国产精品黄毛片入口| 欧洲日本亚洲国产区| 欧美最猛性xxxx| 欧美日韩激情视频|