BFC详解
Posted 勤劳的小叶酱
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
以上是关于BFC详解的主要内容,如果未能解决你的问题,请参考以下文章
14.VisualVM使用详解15.VisualVM堆查看器使用的内存不足19.class文件--文件结构--魔数20.文件结构--常量池21.文件结构访问标志(2个字节)22.类加载机制概(代码片段