2.高度塌陷全解版

文章介绍了CSS布局中由于浮动元素导致的父元素高度塌陷现象,并通过三个示例展示了不同浮动情况对父元素高度的影响。接着,提出了两种解决方法:利用BFC(块格式化上下文)的overflow:hidden属性,以及使用清除浮动的clearfix方案,确保父元素能正确包含浮动的子元素,从而恢复其高度。
摘要由CSDN通过智能技术生成

高度塌陷现象: 当父元素里面的子元素设置了浮动,父元素的高会受到影响的现象,对比以下三种情况观察父元素的高度变化

  1. 不浮动即float:none的时候,父元素的高度是由子元素撑开的.即big高度为400px+10px像素的边框线

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .big{
      width: 400px;
      background-color: aqua;
      border: 5px solid green;
    }
    .box1{
      height: 200px;
      background-color: red;
      float: none;
    }
    .box2{
      height: 200px;
      background-color: purple;
      float: none;
    }
  </style>
</head>
<body>
  <div class="big">
    <div class="box1"></div>
    <div class="box2"></div>
  </div>
</body>
</html>

2 给其中一个加float:left,另一个不加的情况,此时box1加了浮动就会飘起来不占位.高度就是0了,而box2没加.依然占位,所以父元素的高由box2撑开,所以big高度为200px+10px的边框线

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    .big{
      width: 400px;
      background-color: aqua;
      border: 5px solid green;
    }
    .box1{
      height: 200px;
      background-color: red;
      float: left;
    }
    .box2{
      height: 200px;
      background-color: purple;
    }
  </style>
</head>
<body>
  <div class="big">
    <div class="box1"></div>
    <div class="box2"></div>
  </div>
</body>
</html>
  1. 两个子元素全部浮动的情况,box1 和box2全部浮动,都不占位了.高度都为0了,所以此时就没有子元素撑开父元素了,父元素的高度就只剩10px的边框线了

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    .big{
      width: 400px;
      background-color: aqua;
      border: 5px solid green;
    }
    .box1{
      height: 200px;
      background-color: red;
      float: left;
    }
    .box2{
      height: 200px;
      background-color: purple;
      float: left;
    }
  </style>
</head>
<body>
  <div class="big">
    <div class="box1"></div>
    <div class="box2"></div>
  </div>
</body>
</html>

高度塌陷常用解决办法

BFC原理解决: 让父元素触发BFC,即添加overflow:hidden,因为BFC区域内浮动的元素参与高度计算

给big添加了overflow:hideen以后,父元素big就触发了BFC,就算里面的子元素都浮动了,仍然参与计算,所以big的高度为400px+10px=410px

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    .big{
      width: 400px;
      background-color: aqua;
      border: 5px solid green;
      overflow: hidden;
    }
    .box1{
      height: 200px;
      background-color: red;
      float: left;
    }
    .box2{
      height: 200px;
      background-color: purple;
      float: left;
    }
  </style>
</head>
<body>
  <div class="big">
    <div class="box1"></div>
    <div class="box2"></div>
  </div>
</body>
</html>

万能清除法:

原理是在浮动的元素最后面生成一个空的块元素命名clear_fix,并设置清除浮动的样式,实现清除浮动造成的高度塌陷,此时父元素高度就是400px+10px=410px

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    .clear_fix::after{
      content: "";
      display: block;
      clear: both;
      width: 0;
      height: 0;
      overflow: hidden;
      visibility: hidden;
    }
    .big{
      width: 400px;
      background-color: aqua;
      border: 5px solid green;
    }
    .box1{
      height: 200px;
      background-color: red;
      float: left;
    }
    .box2{
      height: 200px;
      background-color: purple;
      float: left;
    }
  </style>
</head>
<body>
  <div class="big clear_fix">
    <div class="box1"></div>
    <div class="box2"></div>
  </div>
</body>
</html>

其他办法(不推荐,有弊端)

  1. 父元素高度写固定,不利于页面排版不灵活

  1. 浮动的元素后面加一个空的div设置clear:both;的样式,也不推荐,因为会造成结构复杂,代码冗余

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值