CSS--BFC规则的作用

原理解释——block formatting context

下列情况将创建一个块格式化上下文:

  • float的值不为none
  • position的值为absolute或fixed
  • overflow的值不为visible(默认就是visible,所以要改变必须显式设置)
  • display的值为table-cell, table-caption, flex, inline-flex, inline-block,中的任何一个
  • 根元素(其中除了inline-flex和inline-block的前后不会强制进行换行以外,其他都会三者都会使元素强制前后换行。)

BFC应用要点:

  1. BFC不会和浮动元素重叠。
  • 例:普通浮动
普通float.png
  • 例:将右边变成BFC(添加overflow:hidden)
左边浮动,右边BFC.png
  • 解析:右边设置了BFC后,由于(1)BFC不能与浮动元素重叠,所以这里BFC自动避让开,就像两者接壤处有一条边界,BFC永远不会超过。并且如果想在BFC上设置margin-left使两者有间隔,这个将遏制必须大于图片的宽度,因为(2)每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。
  1. BFC会计算内部浮动元素的高度
  • 当父元素不是BFC,且未设置高度,而内部又有浮动元素时:
无BFC的浮动.png
  • 如果把父元素改成BFC,它就会识别到内部浮动元素的高度,从而将自己的高度撑开,避免高度塌陷
有BFC的浮动.png
  1. 利用上面的父容器会计算内部浮动元素高度的特性,可以使父元素形成闭合浮动,从而让浮动不影响其他元素,达到清楚浮动的目的。

  2. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。

  3. BFC可以解决上下margin重叠的问题:

  • BFC内部的Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠,但只要两个中有一个不属于父BFC,或两者都创建了新的BFC,那么margin就不会发生重叠
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,056评论 1 92
  • 一、BFC是什么? 它是 Block Formatting Context (块级格式化上下文) 的简称,接下来通...
    07120665a058阅读 3,916评论 15 40
  • relative:生成相对定位的元素,通过top,bottom,left,right的位置相对于其正常位置进行定位...
    zx9426阅读 1,063评论 0 2
  • 文章版权归饥人谷_Lyndon以及饥人谷所有。 1. 浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分...
    HungerLyndon阅读 2,463评论 4 10
  • 深秋的夜 有些凉意 淅淅沥沥的雨滴 肆无忌惮的跳着 昏黄的路灯 孤独的背影 前方的路途 何时才能停 夏日的夜 早已...
    深深浅浅的蓝阅读 190评论 0 0

友情链接更多精彩内容