????????FC(Formatting Contexts),是CSS2.1的一个概念,是页面中的一块渲染区域,具有一套渲染规则,决定FC中子元素如何定位,以及和其他元素的关系和相互作用。在说FC之前说一下文档流。
????????元素按照其所有HTML中的位置先后位置至上而下布局,行内元素水平排列,直到当前行被占满然后换行,块级元素则会被渲染为新的完整的一行,元素默认都是普通流定位。
? ? ? ? 当一个元素被设置浮动效果后,它会脱离普通流,向左右向右偏移所在容器的边框位置,或碰到另一个浮动元素为止。
? ? ? ? 元素会整体脱离普通流,因此绝对定位不会对其兄弟元素造成影响。
? ? ? ? BFC(Block Formatting Contexts,块级格式化上下文)是页面上一个隔离渲染区域,BFC中的子元素不会在布局上影响外面的元素。
BFC形成条件:
特性:
????????不在BFC里,块级Box也会垂直排列,这一条规则不用多说
? ? ? ? 块级元素垂直外边距会折叠,即由外边距较大的为准,不会发生margin穿透问题。
<!DOCTYPE html>
<html>
<head>
<style>
.container {
float: left;
width: 100px;
height: 100px;
background-color: red;
}
.box:first-child {
height: 20px;
margin: 10px 0;
background-color: green;
}
.box:last-child {
height: 20px;
margin: 20px 0;
background-color: green;
}
</style>
</head>
<body>
<div class="container">
<div class="box"></div>
<div class="box"></div>
</div>
</body>
</html>
? ? ? ? float元素固定宽度,BFC元素不设置宽度,BFC元素宽度会自适应
<!DOCTYPE html>
<html>
<head>
<style>
.box:nth-child(1) {
float: left; /*既是浮动元素,也是BFC*/
width: 200px;
height: 300px;
margin-right: 10px;
background-color: red;
}
.box:nth-child(2) {
overflow: hidden; /*设置BFC,不被浮动元素覆盖*/
height: 300px;
background-color: purple;
}
</style>
</head>
<body>
<div class="box"></div>
<div class="box"></div>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<style>
.container {
background-color: red;
padding: 5px;
overflow: hidden;
}
.box {
float: left;
height: 20px;
width: 20px;
margin: 20px 0;
background-color: green;
}
</style>
</head>
<body>
<div class="container">
<div class="box"></div>
</div>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<style>
.container {
float: left;
width: 100px;
height: 150px;
background-color: red;
}
.wrapper {
overflow: hidden;
}
.box:first-child {
height: 20px;
margin: 10px 0;
background-color: green;
}
.box:last-child {
height: 20px;
margin: 20px 0;
background-color: green;
}
</style>
</head>
<body>
<div class="container">
<div class="wrapper">
<div class="box"></div>
</div>
<div class="box"></div>
</div>
</body>
</html>
????????IFC(Inline Formatting Contexts,内联格式化上下文)?。
作用:
????????GFC(GridLayout Formatting Contexts,网格布局格式化上下文)
形成条件:
参见【CSS】布局方式梳理和总结-CSDN博客中的CSS3网格布局。
? ? ? ? FFC(Flex?Formatting Contexts,布局格式化上下文)
形成条件:
参见【CSS】布局方式梳理和总结-CSDN博客中的?CSS3 Flex布局。
参见:
区块格式化上下文 - Web 开发者指南 | MDN (mozilla.org)
CSS深入理解流体特性和BFC特性下多栏自适应布局 ? 张鑫旭-鑫空间-鑫生活 (zhangxinxu.com)
注:以上,如有不合理之处,还请帮忙指出,大家一起交流学习~??