争怎路由网:是一个主要分享无线路由器安装设置经验的网站,汇总WiFi常见问题的解决方法。

什么是BFC?BFC的深入解析

时间:2024/1/24作者:未知来源:争怎路由网人气:

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重叠问题

    <style>
    p{
            color: #fff;
            background: #888;
            width: 200px;
            line-height: 100px;
            text-align:center;
            margin: 100px;
      }
    </style>
    <body>
        <p>ABC</p>
        <p>abc</p>
    </body>

    2437296668-5bc7d72d2283a_articlex.png

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

    <style>
    p{
            color: #fff;
            background: #888;
            width: 200px;
            line-height: 100px;
            text-align:center;
            margin: 100px;
        }
    .wrap{
      overflow:hidden;
    }
    </style>
    <body>
       <p>ABC</p>
      <div class="wrap">
        <p>abc</p>
      </div>
    </body>

    3289453035-5bc7d72d228e6_articlex.png

    ②父子元素margin重叠问题

    <style>
    .box{
    width:100px;
    height:100px;
    background:#ccc;
    }
    .wrap {
      background:yellow;
    }
    .wrap h1{
      background:pink;
      margin:40px;
    }
    </style>
    <body>
    <div class="box">box</div>
    <div class="wrap">
      <h1>h1</h1>
    </div>
    </body>

    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不会重叠浮动元素

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

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

    823074653-5bc7d72cf0bef_articlex.png

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

    3633410184-5bc7d72ce3a20_articlex.png

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

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

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

    <style>
    .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
    }
    </style>
    <body>
    <div class="box">
      <div class="box1"></div>
      <div class="box2"></div>
    </div> 
    </body>

    4201106759-5bc7d72ce3499_articlex.png

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

    308038730-5bc7d72ce0822_articlex.png

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


    网站建设是一个广义的术语,涵盖了许多不同的技能和学科中所使用的生产和维护的网站。



    关键词:啥是BFC?BFC的深入解析




    Copyright © 2012-2018 争怎路由网(http://www.zhengzen.com) .All Rights Reserved 网站地图 友情链接

    免责声明:本站资源均来自互联网收集 如有侵犯到您利益的地方请及时联系管理删除,敬请见谅!

    QQ:1006262270   邮箱:kfyvi376850063@126.com   手机版