清除浮动的方式及overflow:hidden能清除浮动的原因

xiaoxiao2021-02-28  52

我们都知道"overflow:hidden"可以溢出隐藏,即当内容元素的高度大于其包含块的高度时,设置该属性即可把内容区域超出来的部分隐藏,使内容区域完全包含在该包含块中。然而"overflow:hidden"还有另外一个特殊的用途,那就是清除包含块内子元素的浮动。我们先来看一个实例:

//html <body> <div class="parent"> <div class="child1"></div> <div class="child2"></div> </div> </body> // css .parent{ width:300px; background:#ddd; border:1px solid; } .child1{ width:100px; height:100px; background:pink; float:left; } .child2{ width:200px; height:50px; background:red; }

结果:

上面的例子中,我们没有设置.parent的高度,所以.parent的高度默认为auto。由于.child1设置了浮动,脱离了文档流,所以.parent中只有.child2这一个文档流元素。现在我们给.parent添加"overflow:hidden":

.parent{ overflow: hidden; }

结果:

我们看到,给父元素添加一句"overflow:hidden",就能让父元素包住这个脱离了文档流的浮动元素,换句话说,"overflow:hidden"可以清除包含块内子元素的浮动的影响。

现在我们看到了现象,可是原因是什么呢?

在解释这个问题之前,我们先了解一下BFC的概念。

BFC

BFC(Block Formatting Context),块级格式化上下文,它规定了内部的块级元素的布局方式,默认情况下只有根元素(即body)一个块级上下文。

1、BFC布局规则

内部的块级元素会在垂直方向,一个接一个地放置;块级元素垂直方向的距离由margin决定。属于同一个BFC的两个相邻的块级元素会发生margin合并,不属于同一个BFC的两个相邻的块级元素不会发生margin合并;每个元素的margin box的左边,与包含border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此;BFC的区域不会与float box重叠;BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素;外面的元素也不会影响到容器里面的子元素;计算BFC的高度时,浮动元素也参与计算。

2、创建一个BFC

首先我们要知道怎样创建BFC。一个BFC可以被显式触发,只需满足以下条件之一:

float的值不为none;overflow的值不为visible;position的值为fixed / absolute;display的值为table-cell / table-caption / inline-block / flex / inline-flex。

3、BFC的应用

1)、消除margin合并

在margin合并这篇博客中,我描述了相邻兄弟元素、父元素与第一个和最后一个子元素、空块元素的margin合并情况。那么对于发生margin合并的元素,我们怎样消除margin合并?

对于父子元素,我们可以通过设置padding、border、inline content、height、min-height、max-height等属性来消除;但是相邻的兄弟元素之间必出现margin合并,这时如果想要消除margin合并,又该怎么办?

我们首先要搞清楚为什么会发生margin合并。这些元素(包括兄弟、父子元素等)之间之所以会发生margin合并,是因为它们属于同一个BFC。所以,我们就知道怎么办了,只要让它们不属于同一个BFC不就可以了?

我们来看在margin合并这篇博客中举过的一个例子:

// html <body> <div class='bro1'></div> <div class='bro2'> </div> </body> // css body{ margin:0; padding:0; } .bro1{ width:300px; height:200px; background:#ddd; margin-bottom:30px; } .bro2{ width:200px; height:100px; background:pink; margin-top:20px; }

结果:

现在我们给.bro1新建一个BFC,并添加 overflow:hidden;,修改代码如下:

// html <body> <div class='special'> <div class='bro1'></div> </div> <div class='bro2'> </div> </body> // css .special{ overflow:hidden; }

结果:

你看!margin合并消除了!

2)、包含浮动子元素

这也是我们今天的主要议题——为什么"overflow:hidden"能清除浮动的影响。我们经常会在父元素里设置某个子元素浮动。浮动后,子元素脱离了文档流,使得父元素无法包住这个浮动的子元素。我们通常在父元素上设置一个clearfix的伪元素来清除浮动;同样,我们可以利用BFC可以包含浮动这一特性来清除浮动,例子已经在本文开头讲过。

我们对本文开头的例子作一个分析:当给.parent设置"overflow:hidden"时,实际上创建了一个超级属性BFC,此超级属性反过来决定了"height:auto"是如何计算的。在“BFC布局规则”中提到:计算BFC的高度时,浮动元素也参与计算。因此,父元素在计算其高度时,加入了浮动元素的高度,“顺便”达成了清除浮动的目标,所以父元素就包裹住了子元素。

除了给.parent设置"overflow:hidden",我们还可以设置"display:inline-block"、"position:absolute"、"float:left"等方式来创建一个BFC,从而达到包裹浮动子元素的效果(具体使用哪种方法要看项目需求):

// css .parent{ /* 具体使用哪个要看界面设计的情况 */ /* overflow: hidden; */ /* display:inline-block; */ /* position:absolute; */ float:left; }

结果:

转载自:https://www.jianshu.com/p/7e04ed3f4bea

清除浮动的方式:

1. 父元素结束之前,添加一个标签

<div style="clear: both;"></div>

优点:简单,易于实现

缺点:添加了没有意义的空标签

2. 父元素设置overflow: auto或者浮动元素设置overflow: hidden

.par { border: 1px solid green; overflow: auto; } .sub { width: 20%; height: 50px; float: left; border: 1px solid red; overflow: hidden; }

缺点:overflow: auto如果超出范围会自动生成一个滚动条,而overflow: hidden可能会导致超出部分直接隐藏且不占用文档流的空间

3. 让父元素本身也浮动

.par { border: 1px solid green; float: left; }

缺点:使得跟父元素相邻的元素的布局受到影响,不推荐使用

4. 使用CSS的after伪元素

.clearfix:after { content: "."; /*生成内容作为最后一个元素,至于content里面是什么没有影响*/ display: block; /*使得生成的元素以块级元素显示,占满剩余空间*/ height: 0; /*避免生成的内容破坏原有空间的高度*/ clear: both; /*闭合浮动*/ visibility: hidden; /*使得生成内容不可见,并允许可能生成内容盖住的内容进行点击和交互*/ } .clearfix { zoom : 1; /*触发IE6/7的haslayout*/ }

转载自:https://blog.csdn.net/dear_mr/article/details/71325719

其他可借鉴文章:http://www.jb51.net/css/67471.html

转载请注明原文地址: https://www.6miu.com/read-2622014.html

最新回复(0)