前端3+1(Day7)7.2
前端3+1(Day7)
简述你对BFC的理解
BFC概念
具有BFC特性的元素可以看作是隔离了的独立容器,容器里的元素不会在布局上影响到外边的元素,并且BFC具有普通容器没有的特性
触发BFC
满足任意一个条件即可触发BFC
-
body 根元素
-
浮动元素:float:除none以外的值
-
绝对定位元素:position(absolute,fixed)
-
display为inline-block,table-cells,flex
-
overflow除了visible以外的值(hidden,auto,scroll)
BFC特性
-
同一个BFC下外边距会发生折叠
<head> <style> div{ width: 100px; height: 100px; background: lightblue; margin: 100px; } </style> </head> <body> <div></div> <div></div> </body>
这边两个div之间间距只有100px,虽然每一个都设置了margin为100px,因为他们都属于同一个BFC容器下(body),所以第一个下边距和第二个的上边距发生了重叠。如果想要避免外边距的重叠,可以将其放在不同的BFC容器中
-
代码如下
<div class="container"> <p></p> </div> <div class="container"> <p></p> </div>
.container { overflow: hidden; } p { width: 100px; height: 100px; background: lightblue; margin: 100px; }
-
BFC可以包含浮动的元素(清除浮动)
我们知道浮动的元素会脱离普通文档流
<div style="border: 1px solid #000;">
<div style="width: 100px;height: 100px;background: #eee;float: left;"></div>
</div>
由于容器内元素浮动,脱离了文档流,所以容器只剩下2px的边框高度
但是如果使用BFC,便可以让外边的容器包裹着浮动元素
<div style="border: 1px solid #000;overflow: hidden">
<div style="width: 100px;height: 100px;background: #eee;float: left;"></div>
</div>
-
BFC可以阻止元素被浮动元素覆盖
<div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div> <div style="width: 200px; height: 200px;background: #eee">我是一个没有设置浮动, 也没有触发 BFC 元素, width: 200px; height:200px; background: #eee;</div>
其实第二个盒子会被第一个元素遮住(但是文字不会被遮盖),我们可以采用BFC来阻止遮盖,只要在第二个增加overflow:hidden
<div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div> <div style="width: 200px; height: 200px;background: #eee overfloor:hidden">我是一个没有设置浮动, 也没有触发 BFC 元素, width: 200px; height:200px; background: #eee;</di