gpt4 book ai didi

css - 高度明确设置为 0 的行内 block 父包装内容

转载 作者:行者123 更新时间:2023-11-28 01:52:06 24 4
gpt4 key购买 nike

JSFiddle demo

在容器元素设置为 display: inline-block 的下拉菜单中,有一个标签(始终可见,切换下拉菜单覆盖)和覆盖元素本身。我将覆盖容器设置为 height: 0 并希望允许覆盖内容超过容器的高度,而不影响任何父元素。但是,我看到了一些奇怪的结果 - 覆盖容器导致下拉菜单的父项也完全包含覆盖内容!

在下面的 HTML 中,ib = 内联 block 和 h0 = height:0 覆盖容器。请参阅 jsfiddle 演示以查看它的运行情况。

<div>
Sort by this
<span id="ib">
<span>LABEL</span>
<div id="h0">
DROPDOWN<br />
</div>
</span>
</div>

我不想在覆盖层上使用 position: absolute,因为我希望覆盖层的内容决定标签的最终宽度。令人惊讶的是,我可以使用以下 CSS 实现预期的结果:

#ib { display: inline-flex; flex-direction: column; }

我很高兴现在使用该解决方法,但也对这种奇怪效果背后的“原因”感兴趣。

最佳答案

您的问题是关于内联 block 元素的 vertical-align 规则。默认情况下它是 baseline,这里是一些规范:

Baseline: Align the baseline of the box with the baseline of the parent box.

另见:

The height of each inline-level box in the line box is calculated. For replaced elements, inline-block elements, and inline-table elements, this is the height of their margin box; for inline boxes, this is their 'line-height'.

来源:https://www.w3.org/TR/CSS2/visudet.html#line-height

CSS assumes that every font has font metrics that specify a characteristic height above the baseline and a depth below it. In this section we use A to mean that height (for a given font at a given size) and D the depth. We also define AD = A + D, the distance from the top to the bottom.

来源:https://www.w3.org/TR/CSS2/visudet.html#inline-box-height

所以你的修复是通过设置 vertical-align: top/bottom/middle/text-top/text-bottom 由您选择。

固定代码:

.dropdown {
display: inline-block;
vertical-align: top;
}

.overlay {
height: 0;
}
<div>
sort by this
<span class="dropdown">
<span>LABEL</span>
<div class="overlay">
DROPDOWN<br />
DROPDOWN<br />
DROPDOWN
</div>
</span>
</div>
<hr />

关于css - 高度明确设置为 0 的行内 block 父包装内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49861868/

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