当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 原生js实现瀑布流布局

原生js实现瀑布流布局

2019年06月13日  | 移动技术网IT编程  | 我要评论
用js实现瀑布流布局以及通过模拟的数据加载图片,已标记注释 效果如图: <!doctype html> <html> <h

用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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网