BFC(block formatting context )块级格式化上下文 ,究竟是什么呢?看完就明白了。。
BFC 目的是什么?目的是为了形成一个完全独立的空间,让空间中的子元素不会影响到外面的布局,怎么样才能形成这样一个独立的空间呢,可以通过设置元素的属性,如果我们设置了某个元素的属性,这个元素的属性使得这个元素形成了一个独立的空间,那么就可以说触发了BFC,到这里还没有明白怎么回事,甚至更加不明白说了什么?接下来看个例子:
以下是一个正常的页面,我们看到效果如下图:
但是当我们的.child这个元素是浮动元素的时候,如下图,可以看到页面的布局乱了,黄色父元素塌陷了,导致后面的正常排列的
绿色元素布局乱了,绿色也跟着上去了,要解决这个问题,我们就得想办法让红色包裹黄色形成一个完全独立的空间,不要影响外面的布局,怎么形成这个独立空间呢?
这个时候,我们对红色元素加上overflow:hidden来清除浮动,就让当前黄色块的立体浮动不存在了,所以黄色不浮动了,它又回到了父元素红色框内,这个时候我们的这个红色块就把黄色块给保护起来了,这样依赖,绿色也回到了自己该存在的地方,如下
像这样的,能够形成一个完全独立空间,并让空间中的子元素不影响外面布局的这种方式,我们就叫触发BFC.以上图为例,触发规则一般又以下几种
1 float不为none,可以是left,right
2 position不为relative和statice,可以是absolute和fixed
3 overflow为auto,scroll和hidden,
4 display值为table-cell或者inline-block,flex,table-caption或者inline-flex
其中1,2是让元素脱离了文档流形成了独立的块
3分析如下:而当某个元素的长宽固定时,设置这个元素的overflow中值为auto和scroll可保证这个独立的块不影响外界布局出现滚动条,当值为hidden时,隐藏溢出也不影响外部布局,现在的这个元素的overflow:hidden指的仅仅解决的是自身元素内容溢出触发的BFC,和上面图片中例子不一样,上面图片中的例子中子元素脱离文档流中的父元素并没有设置宽和高,所以这个子元素不存在需要隐藏,在这个情景中,触发BFC是为了为父元素添加overflow:hidden是为了清除父元素中子元素立体上浮的,称为清除浮动,使用的css样式一样,但是代表的情景和功能不一样,前者是为了隐藏溢出,后者是为了清除浮动,但不论哪种情况,这种方式对页面中形成一个独立的空间是有用的,所以它触发了BFC。
第四种暂时不分析,有时间过来补。
触发了BFC的容器就是页面上的一个完全隔离开的容器,容器中的元素绝对不会影响到外满的元素,为了保证这个规则,出发了BFC的父元素在计算高度时候,不得不让浮动的子元素也参与进来,变相的清除掉了内部浮动的目的,但有时候,出于布局的需要也可能无法给父元素设置这些属性,而解决高度塌陷,常用的还有以下的办法。
1,让父元素也浮动起来,这样父元素也脱离了文档流,父元素就可以自适应子元素的高度,缺点是引起脱离文档的其他问题。
2.给父元素加上一个固定高度,这种情况只能给已知子元素高度的情况,缺点是不灵活。
3.在浮动的元素后面添加一个空元素,设置{clear:both}来清除浮动,缺点增加了无意义的标签。
4.为浮动的最后一个元素设置一个伪元素,::after{clear:both};和3实际上是一个意思,缺点是复用不当会导致代码量增加。
例如页面分为左右两侧,怎么使用BFC来解决文档不正常显示呢?
1.左侧左浮动,右侧设置margin-left.
.left{ float:left;width:200px;height:200px; background:Red;}
.right{height:200px;margin-left:200px;background:yellow}
2.左侧绝对定位,右侧设置margin-left
.left{ position:absolute;top:0px;left:0px;bottom:0px;width:200px;background:red;height:200px;}
.right{ margin-left:200px;background:yellow;height:200px;}
3.右侧元素设置元素的位置,左侧不用处理,类似于上面的,就不演示了。
.right{top:0px;left:200px;right:0px;width:100%;}
在两个兄弟元素垂直排列的时候,如果两个元素又margin,或者其中一个有边框,那么他们两个之间的边框就会重叠显示,显示值为大的那个margin值,如下,
top元素的边框为20,bottom元素边框为30,他们在一起本来应该是50,但是这里面只有30,因为两个垂直方向的元素放在一起,默认边框是重合取大的那个值。要解决这个问题,就需要通过BFC,通过对其中一个元素包裹一层父元素,overflow:hidden这样元素重叠的问题就解决了。
解决后的图:
总结:可以通过BFC来解决的三个常见的问题:
1,浮动元素的父元素高度塌陷。
2.两栏自适应布局
3.外边距垂直方向重合