gpt4 book ai didi

css - :first-child and :nth-child 的奇怪行为

转载 作者:行者123 更新时间:2023-11-28 09:36:00 27 4
gpt4 key购买 nike

这只是我的问题,还是 :first-child:nth-child 的工作方式不合逻辑?

如果只有我一个人,请向我解释它是如何工作的。

这里有 3 个我真的不明白的用法示例:

我的 HTML 如下:

<div class="footer">
<span class="a">a</span>
<div class="b">b</div>
</div>

第一个例子:(由于某些原因没有隐藏b)

body .b:first-child {
display: none;
}

see fiddle

第二个例子:(由于某些原因没有隐藏b)

body .b:nth-child(1) {
display: none;
}

see fiddle

第三个例子:(由于某些原因最终隐藏了b)

body .b:nth-child(2) {
display: none;
}

see fiddle

有人对这种行为有合理的解释吗?

最佳答案

first-childnth-child(1) 表示first child 节点。 span.a 是第一个节点。使用组合选择器并不重要。 .b 不是第一个 child ,所以没有被选中。

在这种情况下,您可以使用 .b:first-of-type 因为 divspan 是不同的类型,但是如果它们是两个 span 都不起作用。使用像 .b 这样的附加选择器对 nth-child 选择器没有多大帮助,除了以下情况:

<div>
<div class=b>b</div>
</div>
<div>
<div>not b</div>
</div>
<div>
<div class=b>b</div>
</div>

那么你可能会用到 .b:first-child

关于css - :first-child and :nth-child 的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26179032/

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