千家信息网

JavaScriptL如何实现瀑布流布局

发表于:2025-11-12 作者:千家信息网编辑
千家信息网最后更新 2025年11月12日,这篇"JavaScriptL如何实现瀑布流布局"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看
千家信息网最后更新 2025年11月12日JavaScriptL如何实现瀑布流布局

这篇"JavaScriptL如何实现瀑布流布局"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"JavaScriptL如何实现瀑布流布局"文章吧。

  一、经典套路:JavaScript+绝对定位

  HTML结构:

  

  ...

  

  

  简单介绍

  

  

  ...

  整个瀑布流区域用一个作为父容器

  瀑布流中的每个数据块用.box作为基本布局,.wrapper呈现样式和实际内容

  CSS样式:

  *{margin:0;padding:0;}html,body{width:100%;height:100%;background-color:#EDEDED;}#main{

  position:relative;

  width:1280px;/*限定父容器的宽度*/

  margin:0auto;

  }.box{

  position:absolute;

  padding:7px;/*不建议使用margin*/

  box-sizing:border-box;

  width:256px;/*限定数据块的宽度*/}.wrapper{

  padding:5px;

  background-color:#fff;

  border:1pxsolid#e4e4e4;

  box-shadow:01px5pxrgba(0,0,0,.2);

  }.pic{

  font-size:0;/*消除行内元素的间隙*/}.picimg{

  width:100%;

  height:auto;

  }.text{

  color:#999;

  background:#FAFAFA;

  font-size:14px;

  padding-top:5px;

  }

  在.box中设置了padding是为了留出视觉上的间距

  之所以不使用margin,是因为后面会使用js获取元素的offsetWidth和offsetHeight

  而这两个属性值是不计算margin的

  JavaScript:

  _window.onload=function(){

  waterFall('main','box')

  }

  functionwaterFall(main,box){varmain=document.getElementById(main);varboxs=main.getElementsByClassName(box);varboxWidth=boxs[0].offsetWidth;//获取每个数据块的宽度

  varmainWidh=main.offsetWidth;//获取主容器的宽度

  varcols=Math.floor(mainWidh/boxWidth);//计算列数

  varheightArr=[];//定义一个存放top值的数组

  for(vari=0;i

  boxs[i].style.top='0px';

  boxs[i].style.left=i*boxWidth+'px';

  }else{//求出最矮盒子的高度

  varminBoxHeight=Math.min.apply(this,heightArr);

  //求出最矮盒子的索引

  varminBoxIndex=getIndex(minBoxHeight,heightArr);

  boxs[i].style.top=minBoxHeight+'px';//顶部间距即最矮盒子的高度

  boxs[i].style.left=minBoxIndex*boxWidth+'px';

  //关键:更新最矮盒子的高度

  heightArr[minBoxIndex]+=boxHeight;

  }

  }

  }

  functiongetIndex(val,arr){for(variinarr){if(val==arr[i]){returni;

  }

  }

  }

  这种方案一开始给.box设置了position:absolute;

  所以在打开页面的时候,如果页面性能较差,可能会出现所有数据块堆叠在一起的情况

  可以将.box的position:absolute替换为float:left,然后在js添加定位样式的时候,再补上position:absolute,视觉上会有所改观

  二、纯CSS3实现瀑布流

  CSS3中新增了一个属性column,可以通过规定列数column-count,让浏览器自适应布局

  只需要删除上面的JavaScript部分,然后修改#main和.box:

  #main{

  width:1280px;

  margin:0auto;

  -webkit-column-count:5;

  column-count:5;

  -webkit-column-gap:0;

  column-gap:0;

  }.box{

  padding:7px;

  box-sizing:border-box;

  width:256px;

  }

  但通过这种方式实现的瀑布流,实际上是按照纵向排列的,而之前的经典方案是按照横向排列的

  作为一个CSS3的新属性,只有IE10及以上的浏览器才支持column

以上就是关于"JavaScriptL如何实现瀑布流布局"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。

很赞哦!
瀑布 内容 宽度 数据 盒子 容器 属性 样式 高度 元素 实际 布局 文章 方案 时候 浏览器 知识 篇文章 经典 视觉 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 互联网云服务器概念股 艾米立互联网科技 钉钉软件开发者照片 2b2t服务器怎么进我的世界 唐山软件开发均价 dayz正版服务器ip c 数据库 类 如何避免被软件开发公司制约 水晶之牙服务器最新 信阳专业网络安全工程师 北京房天下嘉居网络技术有限公司 软件开发咨询费 三年级画的手抄报网络安全 淮安丞时互联网科技有限公司 轻量服务器防火墙报错 服务器ts140 信宜天气预报软件开发 中小学生网络安全知识进行讲解 网络安全认证配置 小程序组和数据库组对接 数据库几百g gis如何建立mdb数据库 乐视 无服务器 数据库家庭住址的数据类型 电商平台开发跨境电商软件开发 段 服务器 徐州拉钩网络技术 数据库四个完整性控制机制 对日的软件开发单体测试 陕西慧易行互联网科技有限公司
0