BFC详解
BFC(block formating context),翻译过来就是块级格式化上下文。我们可以理解为:BFC就是一个Block-level Box内部的Block-level Box布局的一系列规则。下面我们列出将有哪些布局规则并且举例解释说明。
布局规则:
1. 内部的Box会在垂直方向,从顶部开始一个接一个地放置。(即每个块级元素独占一行)
2. Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生叠加。(垂直方向上margin塌陷)
3. 每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。(规则1产生的原因)
4. BFC的区域不会与float box重叠。
5. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
6. 计算BFC的高度时,浮动元素也参与计算。(overflow:hidden清除浮动远离)
如何产生BFC:
-
float 除了none以外的值
-
overflow 除了visible 以外的值(hidden,auto,scroll )
-
display (table-cell,table-caption,inline-block, flex, inline-flex)
-
position值为(absolute,fixed)
规则解释说明:
规则2: Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生叠加。(垂直方向上margin塌陷)
1 <!-- 样式 --> 2 <style> 3 .item { 4 width: 100px; 5 height: 100px; 6 background-color: #f44; 7 margin: 50px; 8 } 9 </style> 10 11 <!-- 结构 --> 12 <div class="item"></div> 13 <div class="item"></div>
上图中两个元素上下都有50px的margin,但是由于规则2,显示出来的间隔只有50px;并没有我们像我们想象中出现100px的间隔。这种现象叫做margin塌陷。并且当上下margin不一致时,取较大的那个值。
规则3: 每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。(规则1产生的原因)
规则4: BFC的区域不会与float box重叠。
1 <!-- 样式 --> 2 <style> 3 .aside { 4 width: 100px; 5 height: 100px; 6 background-color: #f66; 7 float: left; 8 } 9 10 .main { 11 width: 300px; 12 height: 300px; 13 background-color: #fcc; 14 /*overflow: hidden;*/ 15 } 16 </style> 17 18 <!-- 结构 --> 19 <div class="container"> 20 <div class="aside"></div> 21 <div class="main"></div> 22 </div>
当我们注释掉overflow: hidden时:此时两个div满足规则3,与外层border相连,由于浮动的div不占标准文档流位置,所有出现重叠现象;(第一幅图)
当我们添加上overflow: hidden时;此时class为main的div产生BFC,不与float元素重叠,满足规则4,所以class为main的div紧挨浮动的div。(第二幅图)
详细BFC讲解可以参考:http://sentsin.com/web/529.html