理解CSS中的BFC

1. 概念

块级格式化上下文全称Block Formatting Context,简称BFC。

它是一块独立的渲染区域,它规定了在该区域中,常规流块盒的布局。

2. 规则

  • 常规流块盒在水平方向上,必须撑满包含块
  • 常规流块盒在包含块的垂直方向上依次摆放
  • 常规流块盒若外边距无缝相邻,则进行外边距合并
  • 常规流块盒的自动高度和摆放位置,无视浮动元素、定位元素

3. 触发BFC

这个区域由某个HTML元素创建,以下元素会在其内部创建BFC区域:

  • 根元素 意味着,元素创建的BFC区域,覆盖了网页中所有的元素
  • 浮动和绝对定位元素
  • overflow不等于visible的块盒
  • displayinline-blocktable-cellsflex的元素

如图所示:

创建的BFC就是一块独立的渲染区域:

  • 不同的BFC区域,它们进行渲染时互不干扰
  • 创建BFC的元素,隔绝了它内部和外部的联系,内部的渲染不会影响到外部

4. BFC具体规则

4.1 创建BFC的元素,它的自动高度需要计算浮动元素

案例:高度坍塌情况

html 复制代码
<style>
    .container {
            background-color: pink;
    }

    .item {
            float: left;
            width: 200px;
            height: 200px;
            margin: 20px;
            background-color: red;
    }
</style>

<body>

    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>

</body> 
    

结果父元素背景没有显示,因为父元素高度为0,而container时正常块,高度是不会计算浮动元素的高度。

解决方式:

  • 以前使用clearfix,通过自元素进行撑开

    css 复制代码
    	.clearfix::after {
    	content: "";
    	display: block;
    	clear: both;
    }
  • container设置为BFC元素

    css 复制代码
    .container {
    	background-color: pink;
    	/* position: absolute; */
    	/* float: left; */
    	/* 副作用最小 */
    	overflow: hidden;
    }

4.2 创建BFC的元素,它的边框盒不会与浮动元素重叠

案例:兄弟元素,一个设置浮动,一个未设置

html 复制代码
<style>
	.float {
		width: 200px;
		height: 200px;
		margin: 20px;
		background-color: red;
		float: left;
	}

	.container {
		height: 500px;
		background-color: lightblue;
	}
</style>

<body>
	<div class="float"></div>
	<div class="container"></div>
</body>

结果如下图:

出现这种情况,是因为container元素会避开浮动元素。那么如果设置container元素为BFC区域,那么边框不会和浮动元素重叠。

css 复制代码
.container {
        height: 500px;
        background-color: lightblue;
        /* bfc */
        overflow: hidden;
}  
    

此时的container是独立的区域会避开浮动元素,实际上是相当于给container元素设置了一个margin-left,相对于页面的左边距,此时设置container元素的margin-left不生效。

只能设置float元素的margin-right,因为它也是浮动元素的一部分。

4.3 创建BFC的元素,不会和它的子元素进行外边距合并

简单来说,处在不同的BFC中的元素,他们的外边距不可能合并,只有相同的BFC外边距才能合并

案例:

html 复制代码
<style>
	.container {
		height: 500px;
		margin: 50px;
		background-color: lightblue;
	}

	.child {
		height: 100px;
		margin: 50px;
		background-color: red;
	}
</style>

<body>

	<div class="container">
		<div class="child"></div>
	</div>
</body>

结果:上外边距塌陷

解决方式:container添加bfc,因为child是在container的bfc下,container是在根元素的bfc下,他们是互补干扰。

总结

主要介绍了块级格式化上下文(BFC)的概念、规则及触发条件,以及BFC的具体规则和一些案例说明。如有错误,请指正!O^O

相关推荐
也无晴也无风雨1 小时前
深入剖析输入URL按下回车,浏览器做了什么
前端·后端·计算机网络
Martin -Tang2 小时前
Vue 3 中,ref 和 reactive的区别
前端·javascript·vue.js
FakeOccupational3 小时前
nodejs 020: React语法规则 props和state
前端·javascript·react.js
放逐者-保持本心,方可放逐3 小时前
react 组件应用
开发语言·前端·javascript·react.js·前端框架
曹天骄4 小时前
next中服务端组件共享接口数据
前端·javascript·react.js
阮少年、5 小时前
java后台生成模拟聊天截图并返回给前端
java·开发语言·前端
郝晨妤6 小时前
鸿蒙ArkTS和TS有什么区别?
前端·javascript·typescript·鸿蒙
AvatarGiser6 小时前
《ElementPlus 与 ElementUI 差异集合》Icon 图标 More 差异说明
前端·vue.js·elementui
喝旺仔la6 小时前
vue的样式知识点
前端·javascript·vue.js
别忘了微笑_cuicui7 小时前
elementUI中2个日期组件实现开始时间、结束时间(禁用日期面板、控制开始时间不能超过结束时间的时分秒)实现方案
前端·javascript·elementui