一、什么是BFC
Formatting context 是 W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用。最常见的 Formatting context 有 Block fomatting context (简称BFC)和 Inline formatting context (简称IFC)。Block formatting context直译为"块级格式化上下文"。它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。通俗地讲,BFC是一个容器,用于管理块级元素。
又崩了
中
又双崩了
又双灸崩了
又双录缀能了
二、如何创建BFC
块形状上下文(Block Formatting Context,BFC) 是网页页面的可视CSS渲染的重点,是块盒子的布局过程发生的区域,也是区域元素与其他元素交互的。
以下方式会创建块格式上下文:
●根元素()
●浮动元素(元素的float不是 none)
●绝对定位元素(元素的 position为 absolute 或 fixed)
●行内块元素(元素的 display 为 inline-block)
●表格单元格(元素的 display为 table-cell,HTML 表格单元格默认为该值)
●表格标题(元素的 display 为 table-caption,HTML 表格标题默认为该值)
●匿名表格单元格元素(元素的 display为 、 (分别是HTML table、row、tbody、thead、tfoot的默认属性)或 )table、table-rowtable-row-group、table-header-group、table-footer-groupinline-table
●overflow计算值(Computed)不为 visible的块元素
●display实际flow-root 的元素
●contain是 layout、content 或油漆 的元素
●弹性元素(display为 flex 或 inline-flex 元素的直接子元素)
●元素元素(display为 grid 或 inline-grid 元素的直接子元素)
●多列容器(元素的 column-count或 column-width(en-US)不为 为 )auto,包括 column-count1
●column-span 为 all 的元素总是会创建一个新的 BFC,即使元素没有在一个多列容器中(标准变更,铬错误)。
块周围上下文包含了它的元素内部的所有内容。
三、BFC布局规则:
●内部的Box会在垂直方向,一个接一个地放置(即块级元素独占一行)。
●BFC的区域不会与float box重叠(利用这点可以实现自适应两栏布局)。
●内部的Box垂直方向的距离由margin决定。
●属于同一个BFC的两个相邻Box的margin会发生重叠(margin重叠三个条件:同属于一个BFC;相邻;块级元素)。
●计算BFC的高度时,浮动元素也参与计算。(清除浮动 haslayout)
●BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
四、 BFC有哪些特性
特性1:BFC会阻止垂直外边距折叠
按照BFC的定义,只有同属于一个BFC时,两个元素才有可能发生垂直margin的重叠,这个包括相邻元素或者嵌套元素,只要他们之间没有阻挡(比如边框、非空内容、padding等)就会发生margin重叠。
①相邻兄弟元素margin重叠问题
ABC
abc
上面例中两个P元素之间距离本该为200px,然而实际上只有100px,发生了margin重叠。遇到这种情形,我们如何处理? 只需要在p外面包裹一层容器,并触发该容器生成一个BFC。那么两个P便不属于同一个BFC,就不会发生margin重叠了。
ABC
abc
②父子元素margin重叠问题
box
h1
上图wrap元素与h1元素之间l理论上本该有个40px的上下margin值,然而实际上父子元素并没有存在margin值,与此同时,两个div元素的间距为40px。遇到这种情形,我们如何处理? 处理方法其实有很多,在wrap元素中添加:overflow:hidden;或者overflow:auto;使其父元素形成一个BFC;也可以在wrap元素中添加border:1px solid;或是padding:1px;这些都可以有效解决父子元素margin重叠问题。
box
特性2:BFC不会重叠浮动元素
利用这个特性,我们可以创造自适应两栏布局。
我是一个左浮相亲见面会上,她侃侃而
谈,说她以前的男友如何开
动的元素
豪车,住豪宅,经常夸她如
何如何漂亮,一看到她就紧
他看了看她:"我,我
张.他
般看,看到美女,也,也会紧张的说,
说不出话来."她喉懂笑:"你这种搭
浊的方式真老土.""但,但看到不,不
好着的,就,就会结巴."那女的立马脸
变成了猪肝色
我是一个左浮相亲见面会上,她侃侃而谈,说她以前的
男友如何开豪车,住豪宅,经常夸她如何
动的元素
如何漂亮,一看到她就紧张.他看了看
她:"我,我般看,看到美女,也,也
会紧张的说,说不出话来."
"她赚嘴一
笑:"你这种搭讪的方式真老土.
"但,但看到不,不好看的,就,就会结
巴."那女的立马脸变成了猪肝色
特性3:BFC可以包含浮动----清除浮动
我们都知道浮动会脱离文档流,接下来我们看看下面的例子:
由于容器内两个div元素浮动,脱离了文档流,父容器内容宽度为零(即发生高度塌陷),未能将子元素包裹住。解决这个问题,只需要把把父元素变成一个BFC就行了。常用的办法是给父元素设置overflow:hidden。
.box1 { width: 100px; height: 100px; float: left; border: 1px solid #000; } .box2 { width: 100px; height: 100px; float: left; border: 1px solid #000; } .box { background: yellow; overflow: hidden; }