BFC的定义、创建、特性及应用场景

BFC定义

  • BFC(Block formatting context)直译为"块级格式化上下文",是一个独立的渲染区域,只有块级盒子参与,规定了内部盒子如何布局,与其外部互不影响。

BFC创建

  • 根元素
  • float 值不为 none
  • overflow 值不为 visible
  • display 值为 flex, inline-flex, inline-block, table-cell, table-caption, flow-root(无副作用,单纯创建BFC,但此属性很新,要考虑兼容性)
  • position 值为 absolute, fixed

BFC特性

  • 内部 box 会在垂直方向上,一个接一个地放置
  • 每个盒子的左外边距(margin-left)会触碰到容器的左边缘(border-left)(从右到左亦然)
  • bfc 是一个独立的容器,里面的元素不会影响到外面的元素,反之亦然(解决父随子动及 margin 塌陷)
  • bfc 计算高度时,浮动元素也参与计算(清除浮动)

BFC应用场景

  1. 解决父随子动
  2. 解决 margin 塌陷
    对其中一个 box 设置 display: inline-flex / inline-block / table-caption;
  3. 清除浮动
    同级两个 box,若其中一个设置了浮动,可通过对另一个创建 bfc 来清除浮动(在父级 box 创建 bfc 是无效的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值