面试题: BFC(Block Formatting Context)

 BFC (Block Formatting Context),是什么?

我们在页面布局的时候,经常出现以下情况:

  • 这个元素高度怎么没了?
  • 这两栏布局怎么没法自适应?
  • 这两个元素的间距怎么有点奇怪的样子?
  • ......

原因是元素之间相互的影响,导致了意料之外的情况,这里就涉及到BFC概念

BFC 的中文意思是块级格式化上下文,是用于布局块级盒子的独立渲染区域,一个创建了新的 BFC 的盒子是独立布局的,盒子内元素的布局 不会影响盒子外面的元素。简单来说就是 BFC 就是 css 的一个布局概念,是一个独立的区域(容器) 

触发条件

满足下列条件之一就可以触发 BFC:

  • HTML 根元素
  • position 为 absolute 或 fixed
  • float 属性不为 none(常用)
  • overflow 不为 visible(常用)
  • display 为 inline-block, table-cell, table-caption, flex(常用)

可以解决什么问题?

margin 重叠,清除浮动,自适应布局.

防止 margin 重叠(塌陷)

 应用场景

清除元素内部浮动
解决盒子margin合并问题(塌陷也可以解决)
实现元素宽度自适应多列布局
制作右侧盒子自适应宽度的问题(左侧盒子宽度固定,右侧宽度不固定)
当在父元素中只设定一个盒子浮动,另一个不浮动时,会造成第二个盒子在第一个盒子的下方,被覆盖掉一部分(但文字不会被覆盖)。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值