什么是BFC?BFC的深入解析

本篇文章给大家带来的内容是关于什么是bfc?bfc的深入解析 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、什么是BFC

Formatting context 是 W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用。最常见的 Formatting context 有 Block fomatting context (简称BFC)和 Inline formatting context (简称IFC)。Block formatting context直译为”块级格式化上下文”。它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。通俗地讲,BFC是一个容器,用于管理块级元素。

二、如何创建BFC

float为 left|right

overflow为 hidden|auto|scroll

display为 table-cell|table-caption|inline-block|inline-flex|flex

position为 absolute|fixed

根元素

三、BFC布局规则:

内部的Box会在垂直方向,一个接一个地放置(即块级元素独占一行)。

BFC的区域不会与float box重叠(利用这点可以实现自适应两栏布局)。

内部的Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠(margin重叠三个条件:同属于一个BFC;相邻;块级元素)。

计算BFC的高度时,浮动元素也参与计算。(清除浮动 haslayout)

BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。

四、 BFC有哪些特性

特性1:BFC会阻止垂直外边距折叠

按照BFC的定义,只有同属于一个BFC时,两个元素才有可能发生垂直margin的重叠,这个包括相邻元素或者嵌套元素,只要他们之间没有阻挡(比如边框、非空内容、padding等)就会发生margin重叠。

①相邻兄弟元素margin重叠问题

p{        color: #fff;        background: #888;        width: 200px;        line-height: 100px;        text-align:center;        margin: 100px;  }    

ABC

abc

2437296668-5bc7d72d2283a_articlex.png

上面例中两个P元素之间距离本该为200px,然而实际上只有100px,发生了margin重叠。遇到这种情形,我们如何处理?
只需要在p外面包裹一层容器,并触发该容器生成一个BFC。那么两个P便不属于同一个BFC,就不会发生margin重叠了

p{        color: #fff;        background: #888;        width: 200px;        line-height: 100px;        text-align:center;        margin: 100px;    }.wrap{  overflow:hidden;}   

ABC

abc

3289453035-5bc7d72d228e6_articlex.png

②父子元素margin重叠问题

.box{width:100px;height:100px;background:#ccc;}.wrap {  background:yellow;}.wrap h1{  background:pink;  margin:40px;}
box

h1

111613191-5bc7d72d24010_articlex.png

上图wrap元素与h1元素之间l理论上本该有个40px的上下margin值,然而实际上父子元素并没有存在margin值,与此同时,两个p元素的间距为40px。遇到这种情形,我们如何处理?
处理方法其实有很多,在wrap元素中添加:overflow:hidden;或者overflow:auto;使其父元素形成一个BFC;也可以在wrap元素中添加border:1px solid;或是padding:1px;这些都可以有效解决父子元素margin重叠问题。

3039146047-5bc7d72ce2e1d_articlex.png

特性2:BFC不会重叠浮动元素

利用这个特性,我们可以创造自适应两栏布局

.box1{  height: 100px;  width: 100px;  float: left;  background: lightblue;}.box2{width: 200px;  height: 200px;  background: #eee;}
我是一个左浮动的元素
喂喂喂!大家不要生气嘛,生气会犯嗔戒的。悟空你也太调皮了,我跟你说过叫你不要乱扔东西,你怎么又……你看,我还没说完你就把棍子给扔掉了!月光宝盒是宝物,你把它扔掉会污染环境,要是砸到小朋友怎么办,就算砸不到小朋友,砸到花花草草也是不对的。

823074653-5bc7d72cf0bef_articlex.png

上图中,文字围绕着浮动元素排列,不过在这里,这显然不是我们想要的。此时我们可以为.box2元素的样式加上overflow:hidden;使其建立一个BFC,让其内容消除对外界浮动元素的影响

3633410184-5bc7d72ce3a20_articlex.png

这个方法可以用来实现两列自适应布局,效果不错,此时左边的宽度固定,右边的内容自适应宽度。如果我们改变文字的大小或者左边浮动元素的大小,两栏布局的结构依然没有改变!

特性3:BFC可以包含浮动—-清除浮动

我们都知道浮动会脱离文档流,接下来我们看看下面的例子:

.box1{  width:100px;  height:100px;  float:left;  border: 1px solid #000;}.box2{  width:100px;  height:100px;  float:left;  border: 1px solid #000;}.box{  background:yellow}

4201106759-5bc7d72ce3499_articlex.png

由于容器内两个div元素浮动,脱离了文档流,父容器内容宽度为零(即发生高度塌陷),未能将子元素包裹住。解决这个问题,只需要把把父元素变成一个BFC就行了。常用的办法是给父元素设置overflow:hidden。

308038730-5bc7d72ce0822_articlex.png

以上就是什么是BFC?BFC的深入解析的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1612671.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 03:05:18
下一篇 2025年12月9日 07:49:28

相关推荐

  • css3中all属性有什么用?css3中all属性的用法介绍

    本篇文章给大家带来的内容是关于css3中all属性有什么用?css3中all属性的用法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、兼容性 如下图: 兼容性还行, 除了IE不支持,其他浏览器基本上都绿油油,目前自娱自乐,内网项目什么的都是可以用用的。 二、all是干嘛用的…

    2025年12月24日 好文分享
    000
  • css中flex弹性布局的步骤讲解(附代码)

    本篇文章给大家带来的内容是关于css中flex弹性布局的步骤讲解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 html: *{ margin: 0; padding: 0; box-sizing: border-box; } .wrap{ width: 300px; h…

    2025年12月24日 好文分享
    000
  • css中clip-path属性的用法讲解(附代码)

    本篇文章给大家带来的内容是关于css中clip-path属性的用法讲解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 clip-path的使用 polygon 值为多个坐标点组成,坐标第一个值是x方向,第二个值是y方向。 左上角为原点,右下角是(100%,100%)的点。…

    2025年12月24日 好文分享
    000
  • HTML+CSS实现好看的三角形提示框样式

    在浏览网站时,大家有没有发现网站中有各式各样新颖的提示框,那你知道这些好看的提示框怎么制作的吗?这篇文章就和大家分享一个css实现的好看的三角形提示框,有一定的参考价值,感兴趣的朋友可以参考一下。 想要用CSS实现三角形提示框样式需要用到很多CSS中的属性,比如:display属性,border-r…

    2025年12月24日
    000
  • CSS中Overflow的属性是什么?Overflow属性详解

    很多人学习css的时候,不太知道overflow的属性是什么?怎么用overflow的属性,下面创想鸟为你总结一下overflow属性和用法。 我们都知道,盒子的大小和盒子的位置都是可以用css来控制的,但是有些时候,我们的盒子出现内外都改变的时候,css将如何处理呢,假如,我们设置盒子的高度,我们…

    2025年12月24日
    000
  • css怎么让背景图片居中?背景图片居中的方法介绍(代码实例)

    在前端页面的开发中,图片的显示方法有两种,分别为:img标签显示图片,background属性设置为背景图片显示。我们知道img图片可以设置图片居中效果,那么背景图片可以设置居中吗?如何让背景图片居中?本篇文章就给大家介绍css实现背景图片的居中的方法。有一定的参考价值,有需要的朋友可以参考一下,希…

    2025年12月24日
    000
  • HTML+CSS实现页面加载(loading)动画效果

    大家在浏览页面时有没有遇到页面正在loading(加载)的情况,那作为一个前端开发人员,你知道如何用css3和html制作页面加载动画效果吗?这篇文章就和大家分享一个超级简单实用的css3 圆圈加载(loading)动画效果的代码,有一定的参考价值,感兴趣的朋友可以看看。 想要实现loading加载…

    2025年12月24日
    000
  • 浅谈css使用hsl()和hsla()设置颜色值的方法(图文详解)

    css如何使用hsl()和hsla()设置颜色值?本篇文章就给大家浅谈一下css使用hsl()和hsla()设置颜色值的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 css中的两种设置颜色值的方式:hsl()和hsla(),它们基本上都是采用了HSL色彩模式的方法来设置颜色…

    2025年12月24日 好文分享
    000
  • 如何使用纯CSS实现棋盘的错觉动画(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现棋盘的错觉动画(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容器…

    2025年12月24日
    000
  • flex多列布局有哪些?flex四种多列布局的介绍

    本篇文章给大家带来的内容是关于flex多列布局有哪些?flex四种多列布局的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 基本的等分三列布局 .container{ display: flex; width: 500px; height: 200px; } .left{ fl…

    2025年12月24日 好文分享
    000
  • css3学习之flex实现几种多列布局

    本篇文章就给大家介绍css3学习之flex实现几种多列布局的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 基本的等分三列布局 .container{ display: flex; width: 500px; height: 200px; } .left{ flex:1; b…

    2025年12月24日 好文分享
    000
  • css实现两边固定中间自适应布局的四种常用方法

    本篇文章给大家带来的内容是关于css实现两边固定中间自适应布局的四种常用方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 解析四种常用方法以及原理:浮动、浮动内嵌 div、定位、flex。 浮动 .wrap {background: #eee; padding: 20px; } …

    2025年12月24日
    000
  • css中垂直水平居中的实现方法总结(附代码)

    本篇文章给大家带来的内容是关于css中垂直水平居中的实现方法总结(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 最近看到很多面试题目会问:请说出几种使用css完成垂直水平居中的方法?正好看css基础的时候看到一篇文章是讲完全居中的,这边对于文章中的内容做个小结 一、使用a…

    2025年12月24日 好文分享
    000
  • vue数据动态添加和动态绑定思路(图文)

    本篇文章给大家带来的内容是关于vue数据动态添加和动态绑定思路(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 先上案例 首先来分析一下,勾选科目的时候,下面同时增加科目的满分值设置。 以前写jquery的思路:当勾选的时候创建dom节点,然后把dom节点append到父节点…

    2025年12月24日 好文分享
    000
  • css中grid属性的用法介绍(代码)

    本篇文章给大家带来的内容是关于css中grid属性的用法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 grid布局 加在父元素上的属性 grid-template-columns/grid-template-rows 定义元素的行或列的宽高 立即学习“前端免费学习笔记…

    2025年12月24日 好文分享
    000
  • css3如何实现图片滤镜效果?filter滤镜属性实现(图文详解)

    css3如何实现图片滤镜效果?其实很简单css3 filter属性就可以实现好几种滤镜效果。本篇文章就给大家介绍css3 filter属性可以实现的滤镜效果有哪些,这些图片滤镜效果是如何实现的。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先,我们先建立一个demo,代码如下:…

    2025年12月24日 好文分享
    000
  • 如何使用纯CSS实现一把雨伞开合的动画效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一把雨伞开合的动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 do…

    2025年12月24日
    000
  • css怎么给图片添加阴影效果?图片添加阴影的两种方法(代码实例)

    css可以实现很多的图片效果,图片阴影效果就是其中之一,那么css如何给图片添加阴影效果?本篇文章就给大家介绍如何使用css给图片添加阴影(附代码),让大家了解css给图片加阴影的两种方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助。 首先我们来看看css给图片添加阴影效果的第一种…

    2025年12月24日
    000
  • CSS3学习之页面加载动画(四)

    本篇文章再给大家分享6种css3的页面加载动画。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【CSS3学习之页面加载动画(三)】中又分享了6个CSS3的加载动画,今天继续分享(标题接上一次),图片看得不真切。 十七、效果十七 三个小球,纵向居中,间距撑开,依次改变小…

    2025年12月24日 好文分享
    000
  • CSS3学习之页面加载动画(五)

    之前发了四篇,二十二个效果,本篇文章再给大家分享6种css3的页面加载动画,总计二十八个页面加载动画效果。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【CSS3学习之页面加载动画(四)】中又分享了6个CSS3的加载动画,今天继续分享(标题接上一次)。 二十三、效果二…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信