zoukankan      html  css  js  c++  java
  • BFC详解

      BFC(block formating context),翻译过来就是块级格式化上下文。我们可以理解为:BFC就是一个Block-level Box内部的Block-level Box布局的一系列规则。下面我们列出将有哪些布局规则并且举例解释说明。

    布局规则:

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

      2. Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生叠加。(垂直方向上margin塌陷)

      3. 每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。(规则1产生的原因)

      4. BFC的区域不会与float box重叠。

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

      6. 计算BFC的高度时,浮动元素也参与计算。(overflow:hidden清除浮动远离)

    如何产生BFC:

    1. float 除了none以外的值

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

    3. display (table-cell,table-caption,inline-block, flex, inline-flex)

    4. position值为(absolute,fixed)

    规则解释说明:

      规则2: Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生叠加。(垂直方向上margin塌陷)

     1 <!-- 样式 -->
     2     <style>
     3     .item {
     4         width: 100px;
     5         height: 100px;
     6         background-color: #f44;
     7         margin: 50px;
     8     }
     9 </style>
    10 
    11 <!-- 结构 -->
    12 <div class="item"></div>
    13 <div class="item"></div>

    上图中两个元素上下都有50px的margin,但是由于规则2,显示出来的间隔只有50px;并没有我们像我们想象中出现100px的间隔。这种现象叫做margin塌陷。并且当上下margin不一致时,取较大的那个值。

    规则3: 每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。(规则1产生的原因)

    规则4: BFC的区域不会与float box重叠。

     1 <!-- 样式 -->
     2     <style>
     3     .aside {
     4         width: 100px;
     5         height: 100px;
     6         background-color: #f66;
     7         float: left;
     8     }
     9     
    10     .main {
    11         width: 300px;
    12         height: 300px;
    13         background-color: #fcc;
    14         /*overflow: hidden;*/
    15     }
    16 </style>
    17 
    18 <!-- 结构 -->
    19     <div class="container">
    20         <div class="aside"></div>
    21         <div class="main"></div>
    22     </div>

    当我们注释掉overflow: hidden时:此时两个div满足规则3,与外层border相连,由于浮动的div不占标准文档流位置,所有出现重叠现象;(第一幅图)

    当我们添加上overflow: hidden时;此时class为main的div产生BFC,不与float元素重叠,满足规则4,所以class为main的div紧挨浮动的div。(第二幅图)

                             

    详细BFC讲解可以参考:http://sentsin.com/web/529.html

  • 相关阅读:
    Java 获取本机IP
    IDEA2017.3.1破解激活
    java访问https绕过证书信任
    windows版nginx+ftp实现图片服务器的搭建
    json转字符串,json转list,json转pojo的工具类
    文件上传到ftp服务工具类
    一个servlet处理多个功能
    一二级栏目的查询
    后台接收URL地址的参数
    SSH邮箱验证与激活
  • 原文地址:https://www.cnblogs.com/diligentYe/p/6407300.html
Copyright © 2011-2022 走看看