BFC

定义

BFC(块级格式化上下文)
一个BFC是一个至少满足以下一个条件的盒子:

1.float不为none
2.overflow不为visible
3.display为table-cell, table-caption或者inline-block, flex, inline-flex
4.position不为static或者relative
5.根元素
它们将会建立一个新的块级格式化上下文。

用处

1.利用BFC可以消除Margin Collapse(还可以用padding消除Margin Collapse)

HTML代码:

<div class="container">
  <p>Sibling 1</p>
  <p>Sibling 2</p>
  <p>Sibling 3</p>
</div>

CSS代码:

.container {
  background-color: red;
  overflow: hidden; /* creates a block formatting context */
}

p {
  background-color: lightgreen;
  margin: 10px 0;
}

现在HTML变成:

<div class="container">
  <p>Sibling 1</p>
  <p>Sibling 2</p>
  <div class="newBFC">
    <p>Sibling 3</p>
  </div>
</div>

CSS也有改变:

.container {
  background-color: red;
  overflow: hidden; /* creates a block formatting context */
}
 
p {
  margin: 10px 0;
  background-color: lightgreen;
}
 
.newBFC {
  overflow: hidden;  /* creates new block formatting context */
}

2.利用BFC去容纳浮动元素(还可以用clearfix清除浮动)
HTML:

<div class="container">
  <div>Sibling</div>
  <div>Sibling</div>
</div>  

CSS:

.container {
  background-color: green;
}
 
.container div {
  float: left;
  background-color: lightgreen;
  margin: 10px;
}

我们现在让container形成BFC规则,结果如下:

.container {
  overflow: hidden; /* creates block formatting context */
  background-color: green;
}
 
.container div {
  float: left;
  background-color: lightgreen;
  margin: 10px;
}

3.3.利用BFC阻止文本换行(还可以用margin-left阻止文本换行)



为p建立BFC即可

特征:

1.内部的盒会在垂直方向一个接一个排列(可以看作BFC中有一个的常规流);
2.处于同一个BFC中的元素相互影响,可能会发生margin collapse;
3.每个元素的margin box的左边,与容器块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此;
4.BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然;
5.计算BFC的高度时,考虑BFC所包含的所有元素,连浮动元素也参与计算;
6.BFC的区域不会与float的元素区域重叠
7.BFC包含创建该上下文元素的所有子元素,但不包括创建了新BFC的子元素的内部元素。(一个元素不能同时存在于两个BFC中)

引用:理解CSS中的BFC(块级可视化上下文)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,687评论 1 92
  • 先前在学习CSS float时,有同学提到了BFC这个词,作为求知好问的好学生,哪里不懂查哪里,那么今天就来研究一...
    这名字真不对阅读 11,585评论 3 19
  • 什么是BFC BFC全称是Block Formatting Context,即块格式化上下文。它是CSS2.1规范...
    陌客百里阅读 3,477评论 3 4
  • 转载自(http://web.jobbole.com/83274/) BFC BFC全称是Block Format...
    居客侠阅读 6,418评论 0 20
  • 雾凝楠竹凉, 风憾松树旁。 漂泊四载冬, 潦倒几人伤。 苍天不解语, 大地但着霜。 为问桃李枝, 何当红白妆。
    果州闻郡阅读 1,238评论 0 1

友情链接更多精彩内容