CSS的格式化上下文FC(BFC,IFC,FFC,GFC)

boyanx2个月前技术教程11

前言

在前端开发中,我们可以用CSS设置元素的样式,美化界面,也可以用CSS设置元素布局,即格式化上下文(Formatting Context),简称为FC

盒模型-BOX

我们的页面是由一个个元素组成的,渲染时会将其抽象为一个个的盒(BOX)进行布局渲染

  • 元素的类型和display属性,决定了一个Box的类型
  • 不同类型的Box,会参与组成不同的FC

我们可以在浏览器控制台输入以下代码,标注查看当前页面的所有盒(BOX):

如下图,盒子模型主要由四部分组成:

  • 内容区(Content):实际内容显示的区域,它的大小可以通过widthheight属性来设置
  • 内边距(Padding):内容区与边框之间的空间,可以通过padding属性来设置,padding不透明且会影响元素的实际尺寸
  • 边框(Border):环绕在内边距之外的边界,可以通过border属性来设置,边框的宽度会增加元素的总尺寸
  • 外边距(Margin):边框之外的空间,可以通过margin属性来设置,外边距透明并且不影响元素的实际尺寸,但会影响元素之间的距离

每个Box都有一个内容区,并可选配内边距边框外边距(其值可为零,边距值可为负数)

内边距边框外边距都可分解为上下左右四个段,并且可以分开独立控制其属性

Box-Sizing属性

box-sizing属性规定了Box的计算方式:

  • content-box(默认值):widthheight只包含内容区,不包括内边距、边框和外边距
  • border-box:widthheight包含内容区、内边距和边框,但不包括外边距

冷知识:display属性有32个可选值

格式化上下文-FC

Formatting context(FC:格式化上下文),是W3C CSS2.1规范中的一个概念

它是页面中的一块渲染区域,并且有一套渲染规则,其决定了元素是如何排布、对齐和交互的

常见的FC有:

  • BFC块级格式化上下文(Block Formatting Context)
  • IFC行内格式化上下文(Inline Formatting Context)
  • GFC网格格式化上下文(Grids Formatting Context)
  • FFC弹性盒格式化上下文(Flexible Formatting Context)

其中,GFC和FFC就是CSS3引入的新布局模型

BFC

BFC,即块级格式化上下文,用于控制块级元素布局,每个BFC都是一个独立的渲染区域,元素在这个区域内按照一定的规则进行布局,互不影响

特性

外边距折叠:同一个BFC内的相邻块级元素的上下外边距会合并(重叠),以较大的为准

包含浮动元素:BFC可以包含浮动元素,不会被浮动元素影响(利用该特性可清除浮动),计算BFC的高度时,其内的浮动元素也参与计算

防止文字环绕浮动元素:BFC区域(BFC内的块级盒子)不会与浮动元素区域重叠

创建方式

  • float属性不为none
  • position属性为absolutefixed
  • display属性为inline-blocktable-celltable-captionflexinline-flexflowflow-root
  • overflow属性不为visible(即为hiddenscrollauto)

应用场景

  • 清除浮动
  • 防止外边距折叠
  • 包含浮动元素

应用举例

如上图,有a、b两个盒子,a盒子有30的下外边距,b盒子有50的上外边距,两者相邻只展示50外边距(即30与50重叠,展示较大的)

如不想重叠,可以给a或b外部再包围一个父级盒子,然后将其创建为一个新的BFC,如下:

IFC

IFC,即行内元素格式化上下文,按照行框模型进行布局,IFC中的元素会水平排列成一行或多行,每一行称为一个行框(line box);一个IFC可以有多个行框

特性

水平排列:行内元素在水平方向上排列,直到当前行容不下更多元素为止,然后换行;水平方向的paddingbordermargin都有效,垂直方向的不被计算

水平对齐:可以通过text-align属性来控制行内元素的水平对齐方式

浮动优先排列:行框的宽度是由包含块和与其中的浮动元素来决定,一般情况从左到右按先后顺序排列,但float元素会优先排列

不破坏文档流:IFC不会影响块级元素的布局,不会创建新的BFC

创建方式

行内元素或display: inline;

应用场景

  • 行内元素的排列和对齐
  • 控制文字和行内元素的布局

FFC

FFC是由Flexbox布局创建的格式化上下文,Flexbox布局是一种用于一维布局的强大工具,可以方便地对齐和分布容器内的元素,无论是垂直还是水平方向

特性

弹性盒模型:在FFC中,子元素称为弹性项目(flex items),它们可以根据可用空间灵活地调整自己的大小

主轴和交叉轴:FFC有两个轴,主轴(main axis)和交叉轴(cross axis),元素可以沿着这两个轴进行排列

对齐和分布:可以使用各种属性如justify-contentalign-itemsalign-content来控制弹性项目的对齐和分布方式

创建方式

display属性设置为flexinline-flex

应用场景

  • 创建响应式布局
  • 水平和垂直居中
  • 动态调整元素大小

GFC

GFC,即由Grid布局创建的格式化上下文,Grid布局是一种用于二维布局的强大工具,可以精确地控制容器内元素的排列和对齐

特性

  • 网格模型:在GFC中,容器被划分为行和列,子元素称为网格项目(grid items),可以放置在任意网格单元格中
  • 行和列的定义:可以使用grid-template-rowsgrid-template-columns来定义网格的行和列
  • 区域和单元格的对齐:可以使用grid-areajustify-itemsalign-items等属性来控制网格项目的排列和对齐

创建方式

display属性设置为gridinline-grid

应用场景

  • 创建复杂的页面布局
  • 精确控制元素的位置和对齐
  • 响应式设计

参考资料

CSS Box Level:https://www.w3.org/TR/css-box-3/#intro

CSS Display:https://www.w3.org/TR/css-display-3/


相关文章

成为一个优秀的开发人员,从写文档开始

在移动、Web 和桌面应用或 JavaScript 库的开发领域中,文档在应用的成功之路上扮演着非常重要的角色。但如果你曾经编写过文档,就肯定会同意我的看法:编写文档是开发人员最不喜欢做的事情之一。与...

HTML5 零基础完全教程-2-HTML5 基础标签

2. HTML5 基础标签学习目标掌握HTML5常用的文本格式化标签理解语义化容器标签的使用学会使用注释标签熟悉常用的HTML字符实体文本格式化标签HTML5提供了多种标签来格式化文本,使其在页面上以...

vue添加换行效果

在使用Vue开发前端页面的时候,难免会遇到接收的字符串过长,需要让字符串换行。以往在HTML页面开发中,常用的方法是word-wrap:break-word;添加上这行代码后,在块元素定义的宽度不够时...

HTML常用标签概述(可用于网店装修)

HTML标签:所有内容都在标签之内;内放的是头部信息,是对页面的描述,不会直接显示在页面中。内的中设置的是页面的标题,只能放在中;是页面的主体,大部分显示内容都定义在这里。HTML注释::注释不允许嵌...

关于CSS伪类&伪元素的一些知识——CSS学习之路

最近两天接触到了CSS伪类和伪元素之间的关系,伪类和伪元素在css代码中使用:做标识符,同来识别元素。我倒是理解,可是为什么时常见到一会用一个冒号,一会用两个,然后就感觉很迷糊了,于是就有了这一篇文章...

学习 GitHub 风格的 Markdown 语法和格式化 - 带有示例

Markdown 是一种轻量级、开源、易读易写的文本格式化方法,你可以在任何 IDE 或编辑器中将其作为纯文本使用。在 GitHub 上写作时,你可以使用 Markdown 语法和 HTML 元素来扩...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。