BFC块级格式化上下文的方法

2023-05-15

本篇内容主要讲解“BFC块级格式化上下文的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“BFC块级格式化上下文的方法”吧!

  BFC概念

  BFC即Block Formatting Contexts(块级格式化上下文),它是W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用。

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

  通俗一点来讲,可以把BFC理解为一个封闭的大箱子,箱子内部的元素无论如何翻江倒海,都不会影响到外部。

  BFC触发条件

  满足以下条件之一,即可触发BFC:

  float的值不是none

  position的值不是static或者relative

  display的值是inline-block、table-cell、flex、table-caption或者inline-flex

  overflow的值不是visible

  下面的box盒子就是一个BFC独立容器:

  .box{

  width: 100px;

  height: 100px;

  overflow: hidden;   /* 触发了BFC,形成独立盒子 */

  }

  BFC的应用

  在前面介绍盒模型的margin时,出现了传递和叠加的问题,这里可以采用BFC规范来解决,原理就是让盒子形成一个独立的容器,无论里面的子元素如何折腾,都不影响到外面的元素。

  <style>

  .box1 {

  width: 200px;

  height: 200px;

  background: pink;

  overflow: hidden;    /* 触发了BFC,形成独立盒子 */

  }

  .box2{

  width: 100px;

  height: 100px;

  background: skyblue;

  margin-top: 30px;

  }

  </style>

  <div class="box1">

  <div class="box2"></div>

  </div>

  BFC解决传递问题

  <style>

  section{

  overflow: hidden;    /* 触发了BFC,形成独立盒子 */

  }

  .box1 {

  width: 200px;

  height: 200px;

  background: pink;

  margin-bottom: 40px;

  }

  .box2 {

  width: 100px;

  height: 100px;

  background: skyblue;

  margin-top: 30px;

  }

  </style>

  <section>

  <div class="box1"></div>

  </section>

  <section>

  <div class="box2"></div>

  </section>

  BFC解决叠加问题

  BFC还可以解决前面浮动遇到了父容器高度塌陷的问题,也就是不管里面子元素是否浮动,都不会因为脱离文档流对容器高度造成影响。

  <style>

  .box1 {

  width: 200px;

  border: 1px black solid;

  overflow: hidden;     /* 触发了BFC,形成独立盒子 */

  }

  .box2 {

  width: 100px;

  height: 100px;

  background: pink;

  float: left;

  }

  </style>

  <div class="box1">

  <div class="box2"></div>

  </div>

到此,相信大家对“BFC块级格式化上下文的方法”有了更深的了解,不妨来实际操作一番吧!这里是本站网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

《BFC块级格式化上下文的方法.doc》

下载本文的Word格式文档,以方便收藏与打印。