美文网首页
CSS中的BFC及其作用

CSS中的BFC及其作用

作者: 手指乐 | 来源:发表于2019-10-20 21:53 被阅读0次
  • BFC是什么
    BFC 全称为 块格式化上下文 (Block Formatting Context) ,BFC是一个块独立的作用域,决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用。具有BFC特性的元素可以看做是隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素
    将元素设置为不同BFC可以让它们之间保持独立,以消除它们之间的影响

  • 触发BFC的条件
    满足下列条件之一就可以触发BFC
    1:根元素,即html元素
    2:float的值不为none
    3:overflow的值不为visible
    4:display的值为inline-block、table-cell、table-caption
    5:position的值为absolute或者fixed

  • BFC的作用
    可以阻止元素被浮动的元素覆盖(可做两栏布局自适应)
    绿色盒子浮动遮挡了红色盒子


触发红色盒子的BFC,可防止被绿色盒子遮挡


<style>
        *{
            padding:0;
            margin :0;
        }
        .box {
            width: 400px;
            height: 100px;
            margin: 0  auto;
        }
        .green {
            width: 100px;
            height: 50px;
            float: left;
            background-color: green;
        }
        .red {
            width: 200px;
            height: 100px;
            /* float: left; */
            /* display: inline-block; */
            /* display: table-cell; */
            /* overflow: hidden; */
            /* position: absolute; */
            /* position: fixed; */
            background-color: red;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="green"></div>
        <div class="red">BFC</div>
    </div>
</body>

把注释的任意一条打开会触发.red的BFC,让两者处于不同的BFC

  • 解决高度塌陷
    绿盒子设置浮动前,父盒子被撑开高度:


绿盒子设置浮动后,父盒子高度塌陷:



盒子触发BFC可以解决这个问题

<style>
        .box {
            width: 200px;
            border: 1px solid #ccc;
            overflow:hidden;
        }
        .son {
            width: 100px;
            height: 100px;
            background-color: green;
            float: left;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="son"></div>
    </div>
</body>
  • 解决同一个BFC区域的垂直方向margin合并问题
    属于同一个BFC的两个相邻的box的margin会重叠,以大的为主。要想解决这个问题,可以将两个盒子分为不同的BFC中。

在同一个BFC中时:


分为两个不同的BFC之后:


 <style>
        .green {
            width: 200px;
            height: 100px;
            margin-bottom: 20px;
            background-color: green;
        }
        .red {
            width: 200px;
            height: 100px;
            margin-top: 30px;
            background-color: red;
        }
        .box {
            overflow: hidden;

        } 
        .main {
            width: 300px;
            height: 250px;
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
        <div class="main">
            <div class="green"></div>
            <div class="box">
                <div class="red">BFC</div>
            </div>
        </div>   
</body>

相关文章

  • CSS中的BFC及其作用

    BFC是什么BFC 全称为 块格式化上下文 (Block Formatting Context) ,BFC是一个块...

  • 前端常见面试题目(四)

    一、 BFC 及其应用 1、BFC 概念 BFC 就是块级格式上下文,是页面盒模型布局中的一种 CSS 渲染模式,...

  • Jason zeng practice

    CSS 1. 介绍BFC及其应用 BFC的全称是block format context, 块级格式化上下文,简单...

  • CSS中BFC原理及其用处

    一、 什么是BFC? 1 CSS布局的基本单位:Box(盒模型) Box是CSS布局的对象和基本单位,一份网页由多...

  • CSS清除浮动的方法

    BFC CSS中的BFC BFC:block formatting context块级格式化上下文; BFC 与清...

  • 关于 BFC 的布局应用:清除浮动、文字环绕

    关于 BFC 的布局应用:清除浮动、文字环绕 参考文档:理解CSS中BFC BFC(Block Formattin...

  • 前端面试基础题

    BFC、IFC、GFC、FFC CSS2.1中只有BFC和IFC, CSS3中才有GFC和FFC。 到底什么是BF...

  • 技术面经

    加粗代表重点+高频 HTML & CSS 什么是BFC,BFC有什么作用列举你所知道的所有水平垂直居中的方法fle...

  • CSS-BFC的理解

    简介在使用CSS的过程中,经常会听到触发BFC,但是何为BFC。BFC(Block formatting cont...

  • CSS入门(4)

    BFC 是什么?如何生成 BFC?BFC 有什么作用? 全称为block formatting context,中...

网友评论

      本文标题:CSS中的BFC及其作用

      本文链接:https://www.haomeiwen.com/subject/jloamctx.html