CSS的格式化上下文FC(BFC,IFC,FFC,GFC)
zhezhongyun 2025-04-06 00:31 22 浏览
前言
在前端开发中,我们可以用CSS设置元素的样式,美化界面,也可以用CSS设置元素布局,即格式化上下文(Formatting Context),简称为FC
盒模型-BOX
我们的页面是由一个个元素组成的,渲染时会将其抽象为一个个的盒(BOX)进行布局渲染
- 元素的类型和display属性,决定了一个Box的类型
- 不同类型的Box,会参与组成不同的FC
我们可以在浏览器控制台输入以下代码,标注查看当前页面的所有盒(BOX):
如下图,盒子模型主要由四部分组成:
- 内容区(Content):实际内容显示的区域,它的大小可以通过width和height属性来设置
- 内边距(Padding):内容区与边框之间的空间,可以通过padding属性来设置,padding不透明且会影响元素的实际尺寸
- 边框(Border):环绕在内边距之外的边界,可以通过border属性来设置,边框的宽度会增加元素的总尺寸
- 外边距(Margin):边框之外的空间,可以通过margin属性来设置,外边距透明并且不影响元素的实际尺寸,但会影响元素之间的距离
每个Box都有一个内容区,并可选配内边距、边框和外边距(其值可为零,边距值可为负数)
内边距、边框和外边距都可分解为上下左右四个段,并且可以分开独立控制其属性
Box-Sizing属性
box-sizing属性规定了Box的计算方式:
- content-box(默认值):width和height只包含内容区,不包括内边距、边框和外边距
- border-box:width和height包含内容区、内边距和边框,但不包括外边距
冷知识: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属性为absolute或fixed
- display属性为inline-block、table-cell、table-caption、flex、inline-flex、flow或flow-root
- overflow属性不为visible(即为hidden、scroll和auto)
应用场景
- 清除浮动
- 防止外边距折叠
- 包含浮动元素
应用举例
如上图,有a、b两个盒子,a盒子有30的下外边距,b盒子有50的上外边距,两者相邻只展示50外边距(即30与50重叠,展示较大的)
如不想重叠,可以给a或b外部再包围一个父级盒子,然后将其创建为一个新的BFC,如下:
IFC
IFC,即行内元素格式化上下文,按照行框模型进行布局,IFC中的元素会水平排列成一行或多行,每一行称为一个行框(line box);一个IFC可以有多个行框
特性
水平排列:行内元素在水平方向上排列,直到当前行容不下更多元素为止,然后换行;水平方向的padding、border、margin都有效,垂直方向的不被计算
水平对齐:可以通过text-align属性来控制行内元素的水平对齐方式
浮动优先排列:行框的宽度是由包含块和与其中的浮动元素来决定,一般情况从左到右按先后顺序排列,但float元素会优先排列
不破坏文档流:IFC不会影响块级元素的布局,不会创建新的BFC
创建方式
行内元素或display: inline;
应用场景
- 行内元素的排列和对齐
- 控制文字和行内元素的布局
FFC
FFC是由Flexbox布局创建的格式化上下文,Flexbox布局是一种用于一维布局的强大工具,可以方便地对齐和分布容器内的元素,无论是垂直还是水平方向
特性
弹性盒模型:在FFC中,子元素称为弹性项目(flex items),它们可以根据可用空间灵活地调整自己的大小
主轴和交叉轴:FFC有两个轴,主轴(main axis)和交叉轴(cross axis),元素可以沿着这两个轴进行排列
对齐和分布:可以使用各种属性如justify-content、align-items和align-content来控制弹性项目的对齐和分布方式
创建方式
将display属性设置为flex或inline-flex
应用场景
- 创建响应式布局
- 水平和垂直居中
- 动态调整元素大小
GFC
GFC,即由Grid布局创建的格式化上下文,Grid布局是一种用于二维布局的强大工具,可以精确地控制容器内元素的排列和对齐
特性
- 网格模型:在GFC中,容器被划分为行和列,子元素称为网格项目(grid items),可以放置在任意网格单元格中
- 行和列的定义:可以使用grid-template-rows和grid-template-columns来定义网格的行和列
- 区域和单元格的对齐:可以使用grid-area、justify-items和align-items等属性来控制网格项目的排列和对齐
创建方式
将display属性设置为grid或inline-grid
应用场景
- 创建复杂的页面布局
- 精确控制元素的位置和对齐
- 响应式设计
参考资料
CSS Box Level:https://www.w3.org/TR/css-box-3/#intro
CSS Display:https://www.w3.org/TR/css-display-3/
相关推荐
- JavaScript中常用数据类型,你知道几个?
-
本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!作者|慕课网精英讲师Lison这篇文章我们了解一下JavaScript中现有的八个数据类型,当然这并不是JavaScr...
- 踩坑:前端的z-index 之bug一二(zh1es前端)
-
IE6下浮动元素bug给IE6下的一个div设置元素样式,无论z-index设置多高都不起作用。这种情况发生的条件有三个:1.父标签position属性为relative;2.问题标签无posi...
- 两栏布局、左边定宽200px、右边自适应如何实现?
-
一、两栏布局(左定宽,右自动)1.float+margin即固定宽度元素设置float属性为left,自适应元素设置margin属性,margin-left应>=定宽元素宽度。举例:HTM...
- 前端代码需要这样优化才是一个标准的网站
-
网站由前端和后端组成,前端呈现给用户。本文将告诉您前端页面代码的优化,当然仍然是基于seo优化的。 就前端而言,如果做伪静态处理,基本上是普通的html代码,正常情况下,这些页面内容是通过页面模...
- 网页设计如何自学(初学网页设计)
-
1在Dreamweaver中搭建不同的页面,需要掌握HTML的语句了,通过调整各项数值就可以制作出排版漂亮的页面,跟着就可以学习一些可视化设计软件。下面介绍网页设计如何自学,希望可以帮助到各位。Dre...
- 1、数值类型(数值类型有)
-
1.1数据类型概览MySQL的数据类型可划分为三大类别:数值类型:旨在存储数字(涵盖整型、浮点型、DECIMAL等)。字符串类型:主要用于存储文本(诸如CHAR、VARCHAR之类)。日期/...
- 网页设计的布局属性(网页设计的布局属性是什么)
-
布局属性是网站设计中必不可少的一个重要的环节,主要用来设置网页的元素的布局,主要有以下属性。1、float:该属性设置元素的浮动方式,可以取none,left和right等3个值,分别表示不浮动,浮在...
- Grid网格布局一种更灵活、更强大的二维布局模型!
-
当涉及到网页布局时,display:flex;和display:grid;是两个常用的CSS属性,它们都允许创建不同类型的布局,但有着不同的用法和适用场景。使用flex布局的痛点当我们使...
- React 项目实践——创建一个聊天机器人
-
作者:FredrikStrandOseberg转发链接:https://www.freecodecamp.org/news/how-to-build-a-chatbot-with-react/前言...
- 有趣的 CSS 数学函数(css公式)
-
前言之前一直在玩three.js,接触了很多数学函数,用它们创造过很多特效。于是我思考:能否在CSS中也用上这些数学函数,但发现CSS目前还没有,据说以后的新规范会纳入,估计也要等很久。然...
- web开发之-前端css(5)(css前端设计)
-
显示控制一个元素的显示方式,我们可以使用display:block;display:inline-block;display:none;其中布局相关的还有两个很重要的属性:display:flex;和...
- 2024最新升级–前端内功修炼 5大主流布局系统进阶(分享)
-
获课:keyouit.xyz/14642/1.前端布局的重要性及发展历程前端布局是网页设计和开发的核心技能之一,它决定了页面元素如何组织和呈现。从早期的静态布局到现代的响应式布局,前端布局技术经历了...
- 教你轻松制作自动换行的CSS布局,轻松应对不同设备!
-
在网页设计中,自动换行的CSS布局是非常常见的需求,特别是在响应式设计中。它可以让网页内容自动适应不同屏幕尺寸,保证用户在不同设备上都能够获得良好的浏览体验。本文将介绍几种制作自动换行的CSS布局的方...
- 晨光微语!一道 CSS 面试题,伴你静享知识治愈时光
-
当第一缕阳光温柔地爬上窗台,窗外的鸟鸣声清脆悦耳,空气中弥漫着清新的气息。在这宁静美好的清晨与上午时光,泡一杯热气腾腾的咖啡,找一个舒适的角落坐下。前端的小伙伴们,先把工作的疲惫和面试的焦虑放在一边,...
- 2023 年的响应式设计指南(什么是响应式设计优缺点)
-
大家好,我是Echa。如今,当大家考虑构建流畅的布局时,没有再写固定宽度和高度数值了。相反,小编今天构建的布局需要适用于几乎任何尺寸的设备。是不是不可思议,小编仍然看到网站遵循自适应设计模式,其中它有...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML常用标签 (29)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)