[css面试题] 深入理解BFC , 其实没有那么难

什么是BFC

块格式化上下文(Block Formatting Context,BFC)是Web页面的可视化CSS渲染的一部分,是布局过程中生成块级盒子的区域,也是浮动元素与其他元素的交互限定区域。

BFC 是一个独立的布局环境,可以理解为一个容器,在这个容器中按照一定规则进行物品摆放,并且不会影响外面的元素。

创建规则:

  1. 根元素;
  2. float(取值为 left/ right 的元素)
  3. position (取值为 absolute / fixed 的元素)
  4. display (取值为 inline-block 、 table-cell 、 table-caption 、 flex 、inline- flex 之一的元素)
  5. overflow (取值为 auto/ hidden的元素)

它的特性:

  1. 容器内部的元素不会影响到外面的元素
  2. 内部的Box会在垂直方向,从顶部开始一个接一个地放置
  3. Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生叠加,与方向无关
  4. BFC的区域不会与浮动元素重叠,而是紧贴浮动元素

它的作用:

  1. 垂直外边距重叠问题
  2. 自适应两列布局
  3. 去除浮动

什么是垂直外边距重叠问题?
两个box如果都设置了边距,那么在垂直方向上,两个box的边距会发生重叠,以绝对值大的那个为最后结果显示在页面上。

		.box {
			background: red;
			width: 200px;
			height: 200px;
			margin: 20px;
		}
		.box2{
			margin:  30px 20px;
			background: red;
			width: 200px;
			height: 200px;
		}
		<div class="box"></div>
		<div class="box2"></div>

在这里插入图片描述
这个时候可以将box2外层包一个div.content并且设置overflow: hidden,利用bfc特性实现30px+20px=50px的间距,解决兄弟元素之间外边距塌陷。

		.content{
			overflow: hidden; 
		}
		.box {
			background: red;
			width: 200px;
			height: 200px;
			margin: 20px;
		}
		.box2{
			margin:  30px 20px;
			background: red;
			width: 200px;
			height: 200px;
		}
        <div class="box"></div>
		<div class="content">
			<div class="box2"></div>
		</div> 

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲸渔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值