CSS BFC是什么及有什么作用

在了解BFC(Block Formatting Context)之前,我们先来看看FC(Formatting Context)是什么

CSS BFC是什么及有什么作用

这段话来自W3C官网,我们可以得到如下信息:

  • 所有的盒子都属于一个FC

  • 块级元素的布局属于一个BFC。例如div/p/h2等 -> BFC布局中

  • 行内级元素的布局属于一个IFC。例如img/a/span/i -> IFC布局中

简单理解:块级元素所在的布局和上下文就是BFC,行内级元素所在的布局和上下文就是IFC

问题1.块级元素都是在BFC中布局的,那么这个BFC在哪里呢

首先我们先看一下W3C的官方解释:

CSS BFC是什么及有什么作用

MDN上整理出的下了情况会创建BFC:

  • 根元素(html)

  • 浮动元素(元素的float值不是none)

  • 绝对定位元素(元素的position为absolute或者fixed)

  • 行内块元素(元素的display为inline-block)

  • 表格单元格(元素的display为table-cell,HTML表格单元格默认为该值,表格标题(元素的display为table-caption,HTML表格标题默认为该值)row,tbody,thead,tfoot的默认属性)或inline-table)

  • overflow计算值(Computed)不为visible的块元素

  • 弹性元素(display为flex或inline-flex元素的直接子元素)

  • 网格元素(display为grid或inline-grid元素的直接子元素)

  • display值为flow-root的元素

由此可见

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>  </head>  <body>    <div></div>    <div></div>  </body></html>

这段代码中的box1和box2都是在html根元素的BFC中布局的

问题2.BFC的作用

首先先看一下官方文档对BFC作用的描述:

CSS BFC是什么及有什么作用

我们可以得到的信息:

  • 在一个BFC中,盒子会从包含块的顶部开始,在垂直方向上会一个挨着一个摆放,可能很多人都对这一点习以为常,但这点是BFC帮助我们实现的。当我们对某个盒子设置一个margin-较好的时候,BFC会帮助我们解析,然后会在盒子布局时候给一个上边距

  • 在一个BFC中,每个元素的左边缘都会紧贴着包含块的左边缘

  • 在同一个BFC中,在垂直方向上,相邻两个盒子的margin会重叠,值取两者中较大的(可以利用此特性解决margin重叠问题)

作用1:利用BFC解决margin重叠问题
<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>    <style>      .box1 {        height: 200px;        width: 400px;        background-color: orange;        margin-bottom: 30px;      }      .box2 {        height: 150px;        background-color: purple;        margin-较好: 50px;      }    </style>  </head>  <body>    <div></div>    <div></div>  </body></html>

此时box1和box1此时同处于html的BFC中,并且box1和box2在垂直方向上相邻,所以会出现margin重叠,取两者其中较大的值50px

CSS BFC是什么及有什么作用

如何解决呢?可能很多人会想到直接给box1添加一个BFC,所以直接给box1添加个overflow:hidden属性

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>    <style>      .box1 {        height: 200px;        width: 400px;        background-color: orange;        margin-bottom: 30px;        overflow: hidden;      }      .box2 {        height: 150px;        background-color: purple;        margin-较好: 50px;      }    </style>  </head>  <body>    <div></div>    <div></div>  </body></html>

结果呢?

CSS BFC是什么及有什么作用

发现并不起作用。可能此时很多人就懵了,box1此时不是明明已经形成了BFC了嘛,为什么还会发生重叠?让我来给你解释一下,首先此时box1确实是已经形成了BFC(可以理解成box1内部形成了BFC),但是对于box1这个元素的本身,还是和box2同属于html的BFC中,所以还是会发生margin重叠

所以我们要给box1套一层,然后给box1外层的盒子设置BFC

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>    <style>      /* 给box1外层增加一个container盒子,并设置BFC */      .container {        overflow: hidden;      }      .box1 {        height: 200px;        width: 400px;        background-color: orange;        margin-bottom: 30px;      }      .box2 {        height: 150px;        background-color: purple;        margin-较好: 50px;      }    </style>  </head>  <body>    <div>      <div></div>    </div>    <div></div>  </body></html>

此时box1属于container的BFC,而box2属于html的BFC,不属于同一个BFC,所以就能解决margin重叠问题

CSS BFC是什么及有什么作用

作用2:解决浮动高度塌陷问题

当我们给container里面的四个item设置浮动的时候,很明显,这几个元素都会脱离文档流,此时container不会有高度

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>    <style>      .container {        background-color: orange;      }      .item {        width: 400px;        height: 200px;        box-sizing: border-box;        border: 1px solid #000;        float: left;        background-color: #f00;      }    </style>  </head>  <body>    <div>      <div></div>      <div></div>      <div></div>      <div></div>    </div>  </body></html>

CSS BFC是什么及有什么作用

很多网上博主说,通过给container设置一个BFC,内部的浮动元素就会向其汇报高度,然后container就能解决浮动高度塌陷问题,这个做法是正确的,但是这个说法其实是错误,并不是因为其内部的浮动元素向其汇报了高度

事实上,想通过BFC解决高度塌陷问题需要满足两个条件:

  • 浮动元素的父元素触发BFC,形成独立的块级格式化上下文(BFC)

  • 浮动元素的父元素高度为auto

首先我们先看一段W3C的描述

CSS BFC是什么及有什么作用

大致意思为BFC的高度是auto情况下,高度是这样计算:

  • 如果只有inline-level,是行高的顶部和底部的距离

  • 如果有block-level,是有最底层的块上边缘和最底层块盒子的下边缘之间的距离(有margin也会计算在内)

  • 如果有绝对定位元素,将被忽略(所有我们无法通过BFC解决绝对定位的高度塌陷问题)

  • 如果有浮动元素,那么会增加高度以包括这些浮动元素的下边缘(这才是BFC能解决浮动元素塌陷问题的原因,并不是因为浮动元素向上汇报了高度)

所以我们直接给container通过添加overflow属性设置BFC,则由于上述第四条4特性,container会增加高度来包括内部四个item浮动元素下边缘,所以解决了浮动塌陷问题

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8" />    <meta http-equiv="X-UA-Compatible" content="IE=edge" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />    <title>Document</title>    <style>      .container {        background-color: orange;        /* 通过overflow形成BFC */        overflow: hidden;      }      .item {        width: 400px;        height: 200px;        box-sizing: border-box;        border: 1px solid #000;        float: left;        background-color: #f00;      }    </style>  </head>  <body>    <div>      <div></div>      <div></div>      <div></div>      <div></div>    </div>  </body></html>

CSS BFC是什么及有什么作用

感谢各位的阅读,以上就是“CSS BFC是什么及有什么作用”的内容了,经过本文的学习后,相信大家对CSS BFC是什么及有什么作用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

文章标题:CSS BFC是什么及有什么作用,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/25529

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云亿速云认证作者
上一篇 2022年9月15日 下午11:26
下一篇 2022年9月15日 下午11:28

相关推荐

  • vlookup函数的概念是什么

    vlookup函数是什么意思 答:纵向查找函数。 1、vlookup函数能够快速导入列表数据,完成数据核对或查找。 2、在工作中,我们可以使用它在单个或多个表格中查找并核对需要的数据。 3、vlookup函数的语法规则为:VLOOKUP(lookup_value,table_array,col_in…

    2022年9月24日
    16800
  • php索引超出了数组界限如何解决

    索引超出了数组界限解决方法: 1、在test.php文件内使用header设置test.php执行的编码为utf8,避免乱码的出现。 2、随后在test.php文件内创建一个测试数组,对应的索引值分别为0、4、8。 3、在test.php文件中使用array_values方法将上一步的数据重新排序,…

    2022年9月10日
    22800
  • windows edge浏览器和chrome的优点是什么

    edge浏览器chrome哪个好: 答:新版的edge浏览器更好一点。 在使用JavaScript测试后,edge浏览器以平均值103.5击败了谷歌Chrome,这说明它能够更好地处理开发者遇到的性能问题。 edge浏览器和chrome浏览器的优点: edge浏览器: 1、速度更快 edge浏览器已…

    2022年9月8日
    67700
  • windows中c盘怎么扩大

    c盘可以扩大容量。方法:1、利用“win键+X键”选择“磁盘管理”,删除C盘右侧的分区,使其变为未分配分区;2、右键c盘点击“扩展卷”,系统会自动计算出最大扩容量,没特殊扩展需求点击下一步,完成即可。 本教程操作环境:windows10系统、DELL G3电脑。 c盘可以扩大吗 C盘可以扩容,只需要…

    2022年9月6日
    18100
  • mysql如何将值转换为二进制

    3种转换方法:1、使用BIN()函数,可以返回指定数字的二进制值的字符串表示形式,语法“BIN(number)”,参数“number”是一个长整型(BIGINT)数。2、使用CONV()函数,可将一个进制转为另一个进制,语法“CONV(number,10,2)”,能返回指定数字的二进制值。3、使用B…

    2022年9月26日
    40200
  • Node.js源码中cjs模块的加载过程是什么

    相信大家都知道如何在 Node 中加载一个模块: const fs = require(‘fs’);const express = require(‘express’);const anotherModule = require(‘./another-module’); 没错,require 就是加…

    2022年9月8日
    24400
  • line是属于哪个国家的聊天软件

    line是“日本”的聊天软件。LINE是日本公司NHN Japan于2011年推出的一款即时通讯软件;LINE对用户吸引力最大的是聊天表情贴图,超过250种的表情贴图让用户在使用Line时多了一个有趣的心情传达工具,其中line官方设计可爱且特色鲜明的馒头人、可妮兔、布朗熊和詹姆士饱受好评,也让四个…

    2022年9月16日
    73300
  • vue-router中children怎么使用

    关于children的使用 children的使用场景 比如页面左侧显示菜单,右侧显示不同菜单下的内容,类似如下element网站,那么右侧部分的内容就是当前页面的children 存在如下场景,点击导航一跳转至页面1,导航二跳转页面2,且页面1中存在子页面 路由js如下: const routes…

    2022年8月30日
    28300
  • css中设置长度的单位是什么

    css长度单位有:1、em,相对字体长度单位,它的单位长度是根据元素的文本文字垂直长度来决定的;2、rem,相对字体长度单位,只相对根元素即html元素字体大小来确定其长度;3、%,相对于父元素宽度或字体大小的百分比;4、px,像素,是相对于显示器屏幕分辨率而言的;5、vw,相对于浏览器窗口的宽度;…

    2022年9月22日
    21200
  • unlocker如何使用

    unlocker使用方法: 方法一: 1、找到被锁定的文件或软件,右键选中它,点击右键菜单中的“Unlocker”按钮。 2、然后在左边选择要对它进行的动作,再点击“确定”就可以了。 方法二: 1、直接打开软件,它会自动扫描电脑中正在运行的进程。 2、选中需要操作的进程,然后在下方点击“过程结束”,…

    2022年9月24日
    22400
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部