css布局的各种FC简单介绍:BFC,IFC,GFC,FFC

什么是FC?

Formatting Context,格式化上下文,指页面中一个渲染区域,拥有一套渲染规则,它决定了其子元素如何定位,以及与其他元素的相互关系和作用。

BFC

什么是BFC

Block Formatting Context,块级格式化上下文,一个独立的块级渲染区域,该区域拥有一套渲染规则来约束块级盒子的布局,且与区域外部无关。

BFC的约束规则

  1. 内部的BOX会在垂直方向上一个接一个的放置;
  2. 垂直方向上的距离由margin决定。(完整的说法是:属于同一个BFC的俩个相邻的BOXmargin会发生重叠,与方向无关。
  3. 每个元素的左外边距与包含块的左边界相接触(从左到右),即使浮动元素也是如此。(这说明BFC中的子元素不会超出它的包含块,而positionabsolute的元素可以超出它的包含块边界);
  4. BFC的区域不会与float的元素区域重叠;
  5. 计算BFC的高度时,浮动子元素也参与计算;
  6. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然;

BFC的应用

  • 防止margin发生重叠
  • 防止发生因浮动导致的高度塌陷

怎么生成BFC

  • float的值不为none
  • overflow的值不为visible
  • display的值为inline-blocktable-celltable-caption
  • position的值为absolutefixed

display:table也认为可以生成BFC?其实是在于Table会默认生成一个匿名的table-cell,正是这个匿名的table-cell生成了BFC

IFC

什么是IFC

IFC(Inline Formatting Contexts)直译为"行内格式化上下文",IFCline box(线框)高度由其包含行内元素中最高的实际高度计算而来(不受到竖直方向的 padding/margin影响)

IFC有的特性

  1. IFC中的line box一般左右都贴紧整个IFC,但是会因为float元素而扰乱。float元素会位于IFC与与line box之间,使得line box宽度缩短。
  2. IFC中时不可能有块级元素的,当插入块级元素时(如p中插入div)会产生两个匿名块与div分隔开,即产生两个IFC,每个IFC对外表现为块级元素,与div垂直排列。

IFC的应用

  1. 水平居中:当一个块要在环境中水平居中时,设置其为inline-block则会在外层产生IFC,通过text-align则可以使其水平居中。
  2. 垂直居中:创建一个IFC,用其中一个元素撑开父元素的高度,然后设置其vertical-align:middle,其他行内元素则可以在此父元素下垂直居中。

GFC

GFC(GridLayout Formatting Contexts)直译为"网格布局格式化上下文",当为一个元素设置display值为grid的时候,此元素将会获得一个独立的渲染区域,我们可以通过在网格容器(grid container)上定义网格定义行(grid definition rows)和网格定义列(grid definition columns)属性各在网格项目(grid item)上定义网格行(grid row)和网格列(grid columns)为每一个网格项目(grid item)定义位置和空间。

GFC将改变传统的布局模式,他将让布局从一维布局变成了二维布局。简单的说,有了GFC之后,布局不再局限于单个维度了。这个时候你要实现类似九宫格,拼图之类的布局效果显得格外的容易。

FFC

FFC(Flex Formatting Contexts)直译为"自适应格式化上下文",display值为flex或者inline-flex的元素将会生成自适应容器(flex container)

Flex Box由伸缩容器和伸缩项目组成。通过设置元素的 display属性为 flexinline-flex可以得到一个伸缩容器。设置为 flex的容器被渲染为一个块级元素,而设置为 inline-flex的容器则渲染为一个行内元素。

伸缩容器中的每一个子元素都是一个伸缩项目。伸缩项目可以是任意数量的。伸缩容器外和伸缩项目内的一切元素都不受影响。简单地说,Flexbox定义了伸缩容器内伸缩项目该如何布局。

FFC与BFC的区别

FFCBFC有点儿类似,但仍有以下几点区别:

  • Flexbox 不支持 ::first-line::first-letter这两种伪元素
  • vertical-alignFlexbox中的子元素 是没有效果的
  • floatclear属性对 Flexbox中的子元素是没有效果的,也不会使子元素脱离文档流(但是对Flexbox是有效果的!)
  • 多栏布局(column-*) 在 Flexbox中也是失效的,就是说我们不能使用多栏布局在 Flexbox排列其下的子元素
  • Flexbox下的子元素不会继承父级容器的宽
原文链接:segmentfault.com

上一篇:控件设计的方案权衡
下一篇:JS基础入门篇—运算符

相关推荐

  • 这一次终于看懂了BFC

    前言 好像有点标题党了🤣。 没关系,最近复习,也是终于搞懂了以前一知半解的东西。 在这里做个复盘。 在我最早学习BFC时,看到过这样一句话一些问题是BFC触发的,同样也是用BFC来解决。

    8 个月前
  • 边距重叠以及解决方案BFC

    边距重叠有一下三种情况: 首先把所有的margin格式清空 1.父子元素之间 块级父元素与第一个或者最后一个子元素(父元素不存在上边框、上内边距、内联元素、清除浮动)。

    2 年前
  • 详解BFC、IFC、GFC、FFC

    Formatting Context(格式化上下文) Formatting context 是 W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素...

    4 个月前
  • 理解BFC、IFC

    常见定位方案 普通流 (normal flow) 在普通流中,元素按照其在 HTML 中的先后位置至上而下布局,在这个过程中,行内元素水平排列,直到当行被占满然后换行,块级元素则会被渲染为完整的一个新...

    6 个月前
  • 清楚浮动/边界塌陷bfc

    CSS清浮动处理(Clear与BFC) 在CSS布局中float属性经常会被用到,但使用float属性后会使其在普通流中脱离父容器,让人很苦恼 1 浮动带来布局的便利,却也带来了新问题 复制代码 ...

    1 年前
  • 深入理解盒模型与BFC

    标准盒模型与IE盒模型 开发者们都知道,由于历史遗留问题与既定标准的发展,存在着两个css盒模型。即W3C的标准盒模型以及IE的怪异盒模型。在css中,可以用去定义元素的盒模型。

    2 年前
  • 深入理解css之BFC

    BFC的定义 BFC的全称是block formatting context(块状格式化上下文),当BFC起作用的时候,其元素内部无论怎么翻江倒海都不会影响到外部元素,同样,外部元素的变化也不会影...

    2 年前
  • 深入理解 CSS 中的外边距折叠及 BFC

    作为一个前端工程师,在编写 CSS 时外边距折叠及 BFC 都是经常遇到的情况,今天就来做一下总结。 外边距折叠 什么是外边距折叠 在 CSS 中,两个或者多个普通流中相邻盒子的边距在垂直方向上会发生...

    2 个月前
  • 深入学习BFC

    floatnoneoverflowautoscrollhiddendisplaytablecelltablecaptioninlineblockpositionrelativestaticoverfl...

    8 个月前
  • 模拟 vue3.0 rfcs `createComponent` api 中的`props`类型推导

    rfc 中类型推导部分 Type Inference(https://github.com/vuejs/rfcs/blob/functionapis/activerfcs/0000functiona...

    1 年前

官方社区

扫码加入 JavaScript 社区