前端3+1(Day7)7.2

前端3+1(Day7)

简述你对BFC的理解

BFC概念

具有BFC特性的元素可以看作是隔离了的独立容器,容器里的元素不会在布局上影响到外边的元素,并且BFC具有普通容器没有的特性

触发BFC

满足任意一个条件即可触发BFC

  • body 根元素

  • 浮动元素:float:除none以外的值

  • 绝对定位元素:position(absolute,fixed)

  • display为inline-block,table-cells,flex

  • overflow除了visible以外的值(hidden,auto,scroll)

BFC特性

  • 同一个BFC下外边距会发生折叠

    <head>
    <style>
        div{
        width: 100px;
        height: 100px;
        background: lightblue;
        margin: 100px;
        }
    </style>
    </head>
    <body>
        <div></div>
        <div></div>
    </body>
    

这边两个div之间间距只有100px,虽然每一个都设置了margin为100px,因为他们都属于同一个BFC容器下(body),所以第一个下边距和第二个的上边距发生了重叠。如果想要避免外边距的重叠,可以将其放在不同的BFC容器中

  • 代码如下

    <div class="container">
        <p></p>
    </div>
    <div class="container">
        <p></p>
    </div>
    
    .container {
        overflow: hidden;
    }
    p {
        width: 100px;
        height: 100px;
        background: lightblue;
        margin: 100px;
    }
    
  • BFC可以包含浮动的元素(清除浮动)

我们知道浮动的元素会脱离普通文档流

<div style="border: 1px solid #000;">
    <div style="width: 100px;height: 100px;background: #eee;float: left;"></div>
</div>

由于容器内元素浮动,脱离了文档流,所以容器只剩下2px的边框高度

但是如果使用BFC,便可以让外边的容器包裹着浮动元素

<div style="border: 1px solid #000;overflow: hidden">
    <div style="width: 100px;height: 100px;background: #eee;float: left;"></div>
</div>
  • BFC可以阻止元素被浮动元素覆盖

    <div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div>
    <div style="width: 200px; height: 200px;background: #eee">我是一个没有设置浮动, 
    也没有触发 BFC 元素, width: 200px; height:200px; background: #eee;</div>
    

    其实第二个盒子会被第一个元素遮住(但是文字不会被遮盖),我们可以采用BFC来阻止遮盖,只要在第二个增加overflow:hidden

    <div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div>
    <div style="width: 200px; height: 200px;background: #eee overfloor:hidden">我是一个没有设置浮动, 
    也没有触发 BFC 元素, width: 200px; height:200px; background: #eee;</di
    
posted @ 2022-01-10 17:05  summer在writing  阅读(26)  评论(0编辑  收藏  举报