day012:什么是BFC?什么条件下会触发?渲染规则?应用场景有哪些?

mac2024-02-19  41

day012:什么是BFC?什么条件下会触发?渲染规则?应用场景有哪些?

1.什么是BFC?

W3C对BFC的定义如下: 浮动元素和绝对定位元素,非块级盒子的块级容器(例如 inline-blocks, table-cells, 和 table-captions),以及overflow值不为"visiable"的块级盒子,都会为他们的内容创建新的BFC(Block Fromatting Context, 即块级格式上下文)。

2.触发条件

一个HTML元素要创建BFC,则满足下列的任意一个或多个条件即可: 下列方式会创建块格式化上下文:

根元素()

浮动元素(元素的 float 不是 none)

绝对定位元素(元素的 position 为 absolute 或 fixed)

行内块元素(元素的 display 为 inline-block)

表格单元格(元素的 display为 table-cell,HTML表格单元格默认为该值)

表格标题(元素的 display 为 table-caption,HTML表格标题默认为该值)

匿名表格单元格元素(元素的 display为 table、table-row、 table-row-group、table-header-group、table-footer-group(分别是HTML table、row、tbody、thead、tfoot的默认属性)或 inline-table)

overflow 值不为 visible 的块元素 -弹性元素(display为 flex 或 inline-flex元素的直接子元素)

网格元素(display为 grid 或 inline-grid 元素的直接子元素) 等等。

3.BFC渲染规则

(1)BFC垂直方向边距重叠

(2)BFC的区域不会与浮动元素的box重叠

(3)BFC是一个独立的容器,外面的元素不会影响里面的元素

(4)计算BFC高度的时候浮动元素也会参与计算

4.应用场景

1. 防止浮动导致父元素高度塌陷

现有如下页面代码:

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<meta http-equiv="X-UA-Compatible" content="ie=edge">

<title>Document</title>

<style>

.container {

border: 10px solid red;

}

.inner {

background: #08BDEB;

height: 100px;

width: 100px;

}

</style>

</head>

<body>

<div class="container">

<div class="inner"></div>

</div>

</body>

</html>

接下来将inner元素设为浮动:

.inner {

float: left;

background: #08BDEB;

height: 100px;

width: 100px;

}

会产生这样的塌陷效果:

但如果我们对父元素设置BFC后, 这样的问题就解决了:

.container {

border: 10px solid red;

overflow: hidden;

}

同时这也是清除浮动的一种方式。

2. 避免外边距折叠

两个块同一个BFC会造成外边距折叠,但如果对这两个块分别设置BFC,那么边距重叠的问题就不存在了。

现有代码如下:

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<meta http-equiv="X-UA-Compatible" content="ie=edge">

<title>Document</title>

<style>

.container {

background-color: green;

overflow: hidden;

}

.inner {

background-color: lightblue;

margin: 10px 0;

}

</style>

</head>

<body>

<div class="container">

<div class="inner">1</div>

<div class="inner">2</div>

<div class="inner">3</div>

</div>

</body>

</html>

此时三个元素的上下间隔都是10px, 因为三个元素同属于一个BFC。 现在我们做如下操作:

<div class="container">

<div class="inner">1</div>

<div class="bfc">

<div class="inner">2</div>

</div>

<div class="inner">3</div>

</div>

style增加:

.bfc{

overflow: hidden;

}

效果如下:

可以明显地看到间隔变大了,而且是原来的两倍,符合我们的预期。

关于CSS布局问题,先分享到这里,后续会不断地补充,希望对你有所启发。如果对你有帮助的话,别忘了帮忙点个在看哦。

最新回复(0)