我有一堆元素的类名红色,但我似乎不能选择class="red"使用以下CSS规则的第一个元素:
.home .red:第一个孩子{
边框:1px纯红色;
}
< div class = "家" >
< span >等等> < /跨度
< p class = "红色" >第一个< / p >
< p class = "红色" >第二< / p >
< p class = "红色" > < / p >第三
< p class = "红色" >第四< / p >
< / div >
这个选择器出了什么问题,我如何纠正它,以类红色为目标的第一个孩子?
顾名思义,:first-child选择器用于选择父标记的第一个子标记。所以这个例子将工作(刚刚尝试在这里):
<body>
<p class="red">first</p>
<div class="red">second</div>
</body>
但是,如果您将标记嵌套在不同的父标记下,或者类为red的标记不是父标记下的第一个标记,则这将不起作用。
还要注意,这不仅适用于整个文档中的第一个这样的标记,而且适用于每次在它周围包装一个新的父标签,例如:
<div>
<p class="red">first</p>
<div class="red">second</div>
</div>
<div>
<p class="red">third</p>
<div class="red">fourth</div>
</div>
第一个和第三个将是红色的。
对于你的情况,你可以使用:n -of-type选择器:
r: nth-of-type (1)
{
边框:5px纯红色;
}
< div class = "家" >
< span >等等> < /跨度
< p class = "红色" >第一个< / p >
< p class = "红色" >第二< / p >
< p class = "红色" > < / p >第三
< p class = "红色" >第四< / p >
< / div >
归功于Martyn,他删除了包含这种方法的答案。
有关:n -child()和:n -of-type()的更多信息,请访问http://www.quirksmode.org/css/nthchild.html。
请注意,这是一个CSS3选择器,因此一些过时的浏览器版本可能无法正常运行(例如IE8或更老版本)。详情请访问https://caniuse.com/?search=nth-of-type。