原生js实现瀑布流布局

发布时间 - 2026-01-11 00:03:36    点击率:

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

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


# js  # 瀑布流  # 原生JS实现响应式瀑布流布局  # 解析瀑布流布局:JS+绝对定位的实现  # 微信小程序通过js实现瀑布流布局详解  # 纯js实现瀑布流布局及ajax动态新增数据  # 原生JS实现美图瀑布流布局赏析  # JavaScript瀑布流布局实现代码  # 详解javascript实现瀑布流绝对式布局  # JS实现瀑布流布局  # javascript瀑布流布局实现方法详解  # js实现瀑布流布局(无限加载)  # 加载  # 不支持  # 如图  # 相对于  # 大家多多  # 再由  # 滚动条  # 组中  # 具备了  # img  # shadow  # radius  # height  # width  # left  # pic  # border  # ccc  # solid  # auto 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何快速搭建自助建站会员专属系统?  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  Laravel定时任务怎么设置_Laravel Crontab调度器配置  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  Swift中swift中的switch 语句  如何快速配置高效服务器建站软件?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  手机网站制作与建设方案,手机网站如何建设?  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  浅谈javascript alert和confirm的美化  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  Bootstrap CSS布局之列表  南京网站制作费用,南京远驱官方网站?  北京网站制作的公司有哪些,北京白云观官方网站?  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何在万网开始建站?分步指南解析  如何挑选最适合建站的高性能VPS主机?  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  Linux系统命令中screen命令详解  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  JavaScript如何实现音频处理_Web Audio API如何工作?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何快速重置建站主机并恢复默认配置?  详解CentOS6.5 安装 MySQL5.1.71的方法  如何用PHP工具快速搭建高效网站?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  详解jQuery中基本的动画方法  七夕网站制作视频,七夕大促活动怎么报名?  EditPlus 正则表达式 实战(3)  Android 常见的图片加载框架详细介绍  在centOS 7安装mysql 5.7的详细教程  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  如何在阿里云通过域名搭建网站?  Laravel如何与Inertia.js和Vue/React构建现代单页应用  详解Android图表 MPAndroidChart折线图  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  如何用AI帮你把自己的生活经历写成一个有趣的故事?  如何在服务器上三步完成建站并提升流量?  香港服务器租用每月最低只需15元?  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  Python文件异常处理策略_健壮性说明【指导】