首页 / 知识
实现瀑布流布局的俩种方法
2023-04-11 15:07:00
一、经典套路:JavaScript+绝对定位
HTML结构:
<divid="main">
...<divclass="box">
<divclass="wrapper">
<divclass="pic"><imgsrc=""/></div>
<divclass="text">简单介绍</div>
</div>
</div>
...</div>
整个瀑布流区域用一个<divid="main">作为父容器
瀑布流中的每个数据块用.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.length;i++){varboxHeight=boxs[i].offsetHeight;if(i<cols){//第一行heightArr.push(boxs[i].offsetHeight);
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
本文转载自中文网 |
最新内容
相关内容
python如何读取列表中元素的位置?
python如何读取列表中元素的位置?,位置,数据,异常,培训,字符串,元素,索引,方法,示例,结果,python读取列表中元素位置的方法:1、使用index()方python中获取路径的三种方法
python中获取路径的三种方法,工作,代码,情况,培训,下来,路径,文件,也就是,桌面,目录,python中获取路径总结下来分为三种情况:1、获取工作目录python如何调用另一个文件夹中的内
python如何调用另一个文件夹中的内容?,系统,培训,文件,模块,内容,路径,函数,所在,前缀,语句,python中调用另外一个文件夹中的内容:1、同一文件python中怎么对一个数进行因式分解
python中怎么对一个数进行因式分解?,代码,培训,因式分解,因数,个数,最小,整数,数组,假定,分解,1、Python因式分解代码:importtime#对一个数进python怎么找出所有的数字?
python怎么找出所有的数字?,数字,培训,代码,小数点,小数,字符串,整数,表达式,含义,思路,python中获取字符串中所有数字的方法:1、使用正则表达如何在python代码中指定保存的文件
如何在python代码中指定保存的文件格式,代码,培训,文件格式,格式,二进制文件,文件,后缀,以上,方法,更多,python指定保存文件格式的方法:1、保Python如何复制文件中的内容
Python如何复制文件中的内容,盘中,数据,培训,文件,内容,方法,文件夹,路径,源文件,文件名,python复制文件中内容的方法:1、使用shutil.copyfilepython函数里面形参和实参一样吗?
python函数里面形参和实参一样吗?,培训,函数,参数,里面,变量,实际,形式,全称,示例,后面,python函数里面形参和实参不一样。形参全称是形式参实数是不是python的数据类型?
实数是不是python的数据类型?,数字,标准,培训,实数,数据类型,数轴,复数,有限小数,无理数,虚数,实数是python的数据类型。实数,是有理数和无理linux下怎么查看python的包
linux下怎么查看python的包,软件,培训,工具,管理,命令,格式,详细信息,下面,以上,参数,linux中可以使用piplist命令查看安装的python包。pip是python中的open函数如何编码?
python中的open函数如何编码?,数据,系统,可取,培训,文件,参数,函数,时候,表示,模式,python中的open函数可以通过在打开文件时添加encoding参python判断xml是否存在某一节点?
python判断xml是否存在某一节点?,数据,培训,节点,方法,结果,表达式,长度,以上,更多,内容,python中判断xml是否存在某一节点的方法:使用selectN