CSS 父级元素高度为 0 解决方案

本文详细介绍了在CSS布局中,如何解决由于子元素绝对定位或浮动导致的父级元素高度坍塌问题,提供了包括修改定位方式、使用绝对定位与溢出隐藏组合、以及利用伪元素清除浮动等有效策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CSS 中父级元素的高度一般由子元素撑开,不会特意设置高度,但是以下情况会造成父级元素高度坍塌,也就是高度为零,影响后面元素的排版。

  1. 子元素使用绝对定位

  2. 子元素浮动

针对第一种情况,即子元素使用绝对定位,可以使用以下方案:

  • 子元素的绝对定位改为相对定位,如果可以改的话

针对第二种情况,即由子元素浮动造成父元素坍塌,可以使用以下方案:

  1. /*父级元素绝对定位*/
    position: absolute
  2. /*父级元素添加*/
    overflow: hidden;
  3. /*伪元素清除浮动造成的影响*/
    .clearfix::before,.clearfix::after {
                content: "";
                display: block;
                height: 0px;
                line-height: 0px;
                clear: both;
                visibility: hidden;
            }
    /*清除兄弟元素,添加空元素添加样式*/
    <div class="dad">
        <div class="son"></div>
        <div style="clear: both"></div>
    </div>

     

转载于:https://www.cnblogs.com/guotaodexiaoheiban/p/8971282.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值