实现目的
假设你的页面中有几列高度非固定的模块,他们的顶部是对齐的,而他们的高度会随着其内容的增删而变化,你又希望让他们无论如何都能保持高度一致,也就是说高度自适应且保持一致,这时就可以使用以下方法。
具体方法
1.首先给他们设置一个外包裹层。
效果如图:
data:image/s3,"s3://crabby-images/81f45/81f4535e3da0c583c95a59643fa72194dcd60cc1" alt=""
具体如下
html:
<div class="content-wrap">------------外包裹层
<div class="subcontent">------------每一列
[站外图片上传中……(9)]
<div class="text">
<p></p>
</div>
</div>
<div class="subcontent">------------每一列
[站外图片上传中……(10)]
<div class="text">
<p></p>
</div>
</div>
<div class="subcontent">------------每一列
[站外图片上传中……(11)]
<div class="text">
<p></p>
</div>
</div>
</div>
css部分就不说了,无亮点
2.然后给每一个模块设置尽可能大的padding-bottom,这样就隐含的将其父类包裹层高度撑大了,因为包裹层的高度默认是随内部变化而变化的。
效果图:
data:image/s3,"s3://crabby-images/bb74f/bb74f6ae3c7e0910688e62ad7e7debe630364eb4" alt=""
通过底部可以看出他们的高度还是不一致的。但是可以发现,包裹层的高度相当于模块中高度最高的那个。
data:image/s3,"s3://crabby-images/ae4c9/ae4c9decf8ac3932772bd5f43aeffbcb14bb6ac9" alt=""
css:
.subcontent{
padding-bottom:10000px;
}
3.最后通过设置margin-bottom
(负值)来抵消掉撑长的padding-bottom
,可以这样理解,正的margin-bottom
使包裹层向下伸,那么负的margin-bottom
就会使得包裹层向上【卷】。通过设置负的margin-bottom
,使得包裹层向上【卷】,其卷的水平线是一致,但是基线是根据高度最高的那一个模块来决定的(原因已经说过了,包裹层的高度相当于模块中高度最高的那个),最终使得三者高度一致。
data:image/s3,"s3://crabby-images/147ff/147ff4f73e5704ec3a9ec3892b57c0b5a6ad6b2e" alt=""
可以这样理解:
1.三根绳子水平并排放置,长度分别为:50cm,20cm,30cm并且他们的头部在同一水平线上;
data:image/s3,"s3://crabby-images/b532c/b532ce104c4ef3ff8d9c378abe248eafc95fedb1" alt=""
2.然后将他们每一个延长100cm,这样他们现在的高度分别是:150cm,120cm,130cm;
data:image/s3,"s3://crabby-images/52658/526586d9d50acc636a8e6252feac060e8838bb8e" alt=""
3.紧接着拿一把剪刀从底部开始向上剪100cm;
data:image/s3,"s3://crabby-images/676ef/676ef13588156e96e210fcd02d2d35dae71b42c0" alt=""
4.这时他们的长度分别为:50cm,20+30cm,30+20cm。
data:image/s3,"s3://crabby-images/7d2c8/7d2c8077b38f9f6dcbf04992df208b3d2f7c75d6" alt=""
结束
that all
网友评论