百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

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

liuian 2025-02-03 13:59 18 浏览

前言

在前端开发中,我们可以用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/


相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...