我的世界之BFC

什么是BFC?

Block formatting context:块级格式化上下文(直译)。

BFC是一个独立的渲染区域,是Web页面中盒模型布局的CSS渲染模式,其中的元素布局和定位不受外界的影响,并且在一个BFC中,块盒与行盒(行盒由一行中所有的内联元素所组成)都会垂直的沿着其父元素的边框排列。

因为这个“不受外界影响”这个特性,可以用来清除浮动,解决margin塌陷,不被浮动元素覆盖(文字环绕)等。

 

那么如何形成BFC呢?

  1. float 除 none 以外的值;
  2. position(absolute,fixed);
  3. display 为以下其中之一的值 inline-blocks,table-cells,table-captions;
  4. overflow 除了 visible 以外的值(hidden,auto,scroll);
  5. <html>根元素;

 

BFC的布局规则是什么?

  1. 内部的Box会在垂直方向,一个接一个地放置。
  2. Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠【margin塌陷
  3. 每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。
  4. BFC的区域不会与float box重叠。【解决文字环绕
  5. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。【解决margin塌陷
  6. 计算BFC的高度时,浮动元素也参与计算【清除浮动

BFC常用的作用

1)BFC中盒子对齐

对比IFC(行内格式化上下文)的特性,盒子在水平方向一个接着一个排列。块级格式化上下文里的块级盒会在垂直方向一个接着一个排列,即便不在bfc里块级盒子也是垂直排列的。

2)外边距折叠

在常规情况下,两个兄弟盒子之间的垂直距离是由他们最大的外边距决定,而不是外边距之和。

html

<div class="parent">
      <div class="child1"></div>
      <div class="child2"></div>
</div>

css

.parent{
   overflow: hidden;
}

.parent .child1,
.parent .child2 {
   background-color: salmon;
   height: 50px;
}

.child1 {
   margin-bottom: 30px;
}

.child2 {
   margin-top: 50px;
}

从上面的例子可以看出,两个盒子是50px而不是80px,因为垂直外边产生折叠,间距以较大的为准。如何解决呢?使用规则第5条,创建子元素BFC,任意选择其中一个子元素创建BFC。方法如下:

html

    <div class="parent">
      <div class="child1"></div>
      <div class="child-box">
        <div class="child2"></div>
      </div>
    </div>

css

    .child-box {
      overflow: hidden;
    }

效果如下

3)不被浮动元素覆盖(解决文字环绕)

html

 <div class="float">
      <div class="item">我是aa里內容</div>
      <div class="item">
        我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容我是bb里內容
      </div>
 </div>

css

    .item {
      height: 50px;
    }

    .item:nth-child(1) {
      float: left;
      width: 50px;
      background-color: sandybrown;
    }

    .item:nth-child(2) {
      height: 100px;
      background-color: seagreen;
      /* 激活BFC */
      /* 该div会自动适应宽度 */
      /*  overflow: hidden; */
    }

利用BFC防止环绕

4)清除浮动

清除浮动常用的方法overflow:hidden,因为浮动的子盒子无法撑出处于标准文档流的父盒子的height。

创建BFC清除浮动后【为显示区别,父元素加了阴影效果】

此处利用规则6:计算BFC的高度时,浮动元素也参与计算

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值