gpt4 book ai didi

css - CSS 2.1 规范中 "participate"定义中的 “normal flow” 是什么意思?

转载 作者:太空宇宙 更新时间:2023-11-03 22:43:00 25 4
gpt4 key购买 nike

the W3C CSS 2.1 spec says this正常流 的定义| :

Normal flow

Boxes in the normal flow belong to a formatting context, which may be block or inline, but not both simultaneously. Block-level boxes participate in a block formatting context. Inline-level boxes participate in an inline formatting context.

所以我的第一个问题是:“参与”到底是什么意思?

在“ block 格式化上下文”(BFC)的定义中它说:

In a block formatting context, boxes are laid out one after the other, vertically, beginning at the top of a containing block. The vertical distance between two sibling boxes is determined by the 'margin' properties. Vertical margins between adjacent block-level boxes in a block formatting context collapse.

正如我们所知,在 block 容器框(即不是“ block 格式化上下文”)中,框的布局与上面为“ block 格式化上下文”指定的定义完全相同。

所以我的第二个问题是:“参与”是指 block 容器布局的行为与“ block 格式化框”相同吗?

由于我最后一个问题的原因,我引用了这个定义:

In a block formatting context, each box's left outer edge touches the left edge of the containing block (for right-to-left formatting, right edges touch). This is true even in the presence of floats (although a box's line boxes may shrink due to the floats), unless the box establishes a new block formatting context (in which case the box itself may become narrower due to the floats).

当我们创建一个包含一个图像和一个段落,itt 的行为与上面的定义完全一样:

img {
float: left;
}

p {
border: 1px solid red;
}
<div>
<img src="http://placehold.it/100x100&text=1">
<p>
the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like
block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!!
</p>
</div>

即使我们将 p 元素更改为 div 中的 block 格式化上下文,它的行为也与下面的定义完全一样:

img {
float: left;
}

p {
border: 1px solid red;
overflow: auto;
}
<div>
<img src="http://placehold.it/100x100&text=1">
<p>
the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like
block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!! the div element is not block formatting context but behaves like block formatting context!!!
</p>
</div>

如果我们将 div 更改为 block 格式化上下文,它的行为与前面的示例完全相同:

div {
overflow: hidden;
}

img {
float: left;
}

p {
border: 1px solid red;
overflow: hidden;
margin: 0;
}
<div>
<img src = "http://placehold.it/100x100&text=1">
<p>
the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b> the div element is a block formatting context <b>NOW</b>
</p>
</div>

……我说得对吗?

最佳答案

当一个框被称为参与某种格式上下文时,它只是意味着该元素是根据该格式上下文的规则进行布局的。如果元素参与 block 格式化上下文,则它是 block 级的并且由 block 布局控制。如果元素参与内联格式化上下文,则它是内联级别的并且由内联布局控制。等等。

“ block 容器盒”和“ block 格式化上下文”是两个不同的概念,只是松散地相关。您似乎将它们混为一谈,这是不明智的。

block 容器框仅在特定条件下建立 block 格式化上下文。规范中列出了发生这种情况的标准,但基本上 block 容器框没有建立 BFC 的唯一时间是它具有 display: block;溢出:可见; float :无;位置:静态/相对(来自here)。

正如规范中所述,每个 block 级框都参与了一些 block 格式化上下文。它的父 block 容器是否建立BFC并不重要。如果它的父元素没有建立 BFC,那么父元素的父元素,或者父元素的父元素的父元素,或者树中更高层的其他祖先——一直到根元素——会创建。这意味着单个 block 格式化上下文可以——而且几乎总是如此——包含许多元素的嵌套级别。这统称为正常流程。

即使你有一个完整的 block 盒布局,如果它们都没有建立 BFC,那么它们都参与由根元素建立的同一个 BFC(并且根元素保证 建立一个)。在下面的示例中,所有三个元素都参与了根元素的 BFC,因此它们受 block 布局支配,即使它们都没有建立自己的 BFC:

<body>
<div>
<p>
</div>
</body>

讨论了 overflow: hidden 在存在 float 的情况下对 block 格式化上下文的影响 elsewhere ,但简而言之, float 永远不会侵入其他 block 格式化上下文,这就是为什么让 p 建立自己的 BFC 导致它由于 float 而变得更窄。让 div 建立自己的 BFC 不会改变任何东西,因为 p 仍然参与 some BFC,不管你是什么我们只是改变它参与的谁的 BFC。

关于css - CSS 2.1 规范中 "participate"定义中的 “normal flow” 是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43215834/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com