其他分享
首页 > 其他分享> > 高度塌陷?怎么解决

高度塌陷?怎么解决

作者:互联网

1、什么是高度塌陷?

  给子元素设置浮动,导致父元素高度为零或者高度自适应

2、怎么解决高度塌陷?

  清楚浮动(清除浮动主要是为了解决,父元素因为子级元素浮动引起的内部高度为0的问题)

3、清除浮动的解决方式?

方法一、 额外标签法: 给谁清除浮动,就在其后额外添加一个空白标签并添加clear:both属性。

  优点: 通俗易懂,书写方便。(不推荐使用)
  缺点: 添加许多无意义的标签,结构化比较差。

<style>
  .son{
    width:100px;
    height:200px
    float:left
  }
  .clear{
    clear:both
  }
</style>

<div class="parent">
   <div class="son"><div>
  <div class="clear"></div>//给元素son清除浮动(在son后添加一个空白标签clear(类名可以随意),设置clear:both;即可)
</div>

方法二、给父元素添加 overflow:hidden

父级添加overflow方法: 可以通过触发BFC的方式,实现清楚浮动效果。必须定义width或zoom:1,同时不能定义height,使用overflow:hidden时,浏览器会自动检查浮动区域的高度

  优点: 简单、代码少、浏览器支持好

  缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。不能和position配合使用,因为超出的尺寸的会被隐藏。

  注意: 别加错位置,是给父亲加(并不是所有的浮动都需要清除,谁影响布局,才清除谁。)

方法三、使用after伪元素清除浮动: :after方式为空元素的升级版,好处是不用单独加标签了。IE8以上和非IE浏览器才支持:after,,zoom(IE专有属性)可解决ie6,ie7浮动问题(较常用推荐)

  优点: 符合闭合浮动思想,结构语义化正确,不容易出现怪问题(目前:大型网站都有使用,如:腾迅,网易,新浪等等)

  缺点: 由于IE6-7不支持:after,使用zoom:1

.clearfix:after{/*伪元素是行内元素 正常浏览器清除浮动方法*/
   content: "";
   display: block;
  height: 0; clear:both; visibility: hidden; }
.clearfix{ *zoom: 1;/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/ } <div class="parent clearfix"> <div class="son1">son1</div> <div class="son2">son2</div> <!--<div class="clear">额外标签法</div>--> </div>
<div class="footer"></div>

方法四、使用before和after双伪元素清除浮动:(较常用推荐

.parent{
  border: 1px solid black; *zoom: 1; }
.clearfix:after,.clearfix:before{ content: ""; display: block; clear: both; } .son1,.son2{ width: 200px; height: 200px; float: left; }
.son1{ background-color: red; } .son2{ background-color: blue;
}
<div class="parentclearfix">   <div class="son1">son1</div>   <div class="son2">son2</div> </div> <div class="footer"></div>

  

原文链接:https://blog.csdn.net/weixin_43638968/article/details/107617275

标签:浮动,元素,清除,clear,after,高度,zoom,塌陷,解决
来源: https://www.cnblogs.com/mydiary/p/16120787.html