BFC(Block Formatting CoFSADntext)直译为“块级格式化范围”



1.是 W3C CSS 2.1 规范中的一个概念,它决定了元素怎样对其内容进行定位。以及与其他元素的关系和相互作用。

当涉及到可视化布局的时候,Block Formatting Context提供了一个环境,HTML元素在这个环境中依照一定规则进行布局。一个环境中的元素不会影响到其他环境中的布局。比方浮动元素会形成BFC。浮动元素内部子元素的主要受该浮动元素影响,两个浮动元素之间是互不影响的。

这里有点类似一个BFC就是一个独立的行政单位的意思。

也能够说BFC就是一个作用范围。能够把它理解成是一个独立的容器,而且这个容器的里box的布局,与这个容器外的毫不相干。

2.还有一个通俗点的解释是:在普通流中的 Box(框) 属于一种 formatting context(格式化上下文) 。类型能够是 block ,或者是 inline 。但不能同一时候属于这两者。

而且, Block boxes(块框) 在 block formatting context(块格式化上下文) 里格式化, Inline boxes(块内框) 则在 inline formatting context(行内格式化上下文) 里格式化。不论什么被渲染的元素都属于一个 box 。而且不是 block 。就是 inline 。即使是未被不论什么元素包裹的文本,依据不同的情况,也会属于匿名的 block boxes 或者 inline boxes。

所以上面的描写叙述,即是把全部的元素划分到相应的 formatting context 里。


DEMO1:




<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

<title>Examples</title>

<meta name="description" content="">

<meta name="keywords" content="">

<link href="" rel="stylesheet">

<style>

    body {

        width: 300px;

        position: relative;

    }

 

    .aside {

        width: 100px;

        height: 150px;

        float: right;

        background: #f66;

    }

 

    .main {

        height: 200px;

        background: #fcc;

        

    }

</style>

</head>

<body>

    <div class="aside"></div>

    <div class="main"></div>

</body>

</html>


显示效果如图:能够看到因为深红色快的浮动导致不占文档位置所以会浮动在粉红色块上


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_html


开启BFC:




<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

<title>Examples</title>

<meta name="description" content="">

<meta name="keywords" content="">

<link href="" rel="stylesheet">

<style>

    body {

        width: 300px;

        position: relative;

    }

 

    .aside {

        width: 100px;

        height: 150px;

        float: right;

        background: #f66;

    }

 

    .main {

        height: 200px;

        background: #fcc;

         overflow: hidden;

    }

</style>

</head>

<body>

    <div class="aside"></div>

    <div class="main"></div>

</body>

</html>


给当中非浮动的元素加入了overflow:hidden后看到效果例如以下图所看到的:


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_chrome_02


两个div不再堆叠在一起了




DEMO2


<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

<title>Examples</title>

<meta name="description" content="">

<meta name="keywords" content="">

<style>

    .par {

        border: 5px solid #fcc;

        width: 300px;

       

    }

 

    .child {

        border: 5px solid #f66;

        width:100px;

        height: 100px;

        float: left;

    }

</style>

</head>

<body>

      <div class="par">

        <div class="child"></div>

        <div class="child"></div>

    </div>

</body>

</html>




显示效果如图所看到的:因为子节点的浮动导致脱离了父节点文档,所以父节没有被撑开


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_子节点_03


开启BFC:


<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

<title>Examples</title>

<meta name="description" content="">

<meta name="keywords" content="">

<style>

    .par {

        border: 5px solid #fcc;

        width: 300px;

       overflow: hidden;;

    }

 

    .child {

        border: 5px solid #f66;

        width:100px;

        height: 100px;

        float: left;

    }

</style>

</head>

<body>

      <div class="par">

        <div class="child"></div>

        <div class="child"></div>

    </div>

</body>

</html>


效果例如以下图所看到的:给父节点加入了overflowhidden,这时候就能够被子节点撑开了


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_html_04


DEMO3:



<!DOCTYPE html>

<html>  

<head> 

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">

  <!--The viewport meta tag is used to improve the presentation and behavior of the samples 

    on iOS devices-->

  <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no"/>

  <title></title>



  <style> 

    html, body { height: 100%; width: 100%; margin: 0; padding: 0; }

    .left{

      background:pink;

      float: left;

      width:180px;

      height:200px;

    }

    .center{

      background:lightyellow;

      overflow:hidden;

       height:200px;

      

    }

    .right{

      background: lightblue;

      width:180px;

       height:200px;

      float:right;

    }

  </style> 

  

  

</head> 



<body> 

  <div class="container">

    <div class="right">right</div>

    <div class="left">left</div>

    <div class="center">center</div>  

  </div>

</html>


显示效果如图:我们看到三个div成一行排列了,注意这里的cener并没有设置宽度是自己主动撑开的,非常吊!


只是注意一点center必须再html标签的顺序上放在最后才干实现这个效果


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_html_05


DEMO4:


<!DOCTYPE html>

<html>  

<head> 

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">

  <!--The viewport meta tag is used to improve the presentation and behavior of the samples 

    on iOS devices-->

  <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no"/>

  <title></title>



  <style> 

    html, body { height: 100%; width: 100%; margin: 0; padding: 0; }

    .main{border:2px blue solid;}

    .left{

      background:pink;

      float: left;

      width:180px;

      height:200px;

    }

  </style> 

  

  

</head> 



<body> 

<div class="main">

  <div class="c">

    <div class="left">right</div>

    <div class="left">left</div>

  </div>

   <div class="c">

    <div class="left">right</div>

    <div class="left">left</div>

  </div>

</div> 

</html>


显示效果如图所看到的:尽管left div是分别放在两个c div里面的。 可是因为浮动导致子节点脱离文档流 而使子节点不占位 同一时候排成一行来布局


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_ios_06


开启BFC:


<!DOCTYPE html>

<html>  

<head> 

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">

  <!--The viewport meta tag is used to improve the presentation and behavior of the samples 

    on iOS devices-->

  <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no"/>

  <title></title>



  <style> 

    html, body { height: 100%; width: 100%; margin: 0; padding: 0; }

    .main{border:2px blue solid;}

    .c{overflow: hidden;;}

    .left{

      background:pink;

      float: left;

      width:180px;

      height:200px;

    }

  </style> 

  

  

</head> 



<body> 

<div class="main">

  <div class="c">

    <div class="left">right</div>

    <div class="left">left</div>

  </div>

   <div class="c">

    <div class="left">right</div>

    <div class="left">left</div>

  </div>

</div> 

</html>


显示效果如图所看到的:给c div加入了overflow:hidden的时候触发了BFC  所以原本浮动的子节点并没有超出C div来影响到c外的节点,所以变成了两行


CSS定位规则之BFC  你居然一直不知道的东西!!!!!_子节点_07


最后总结:


能够看到本篇文章通篇都是在解说怎样使用overflow来触发BFC,事实上除了overflow外还有其它的触发方法。仅仅只是临时还没遇到先不表,以上代码均通过IE7~[包含IE7]和谷歌的检測,能够放心使用