为什么在嵌套元素上,nth-of-type/nth-child选择器无效?
P粉237689596
2023-08-24 16:07:18
<p>我正在尝试更改嵌套在一个div内的奇数个div的样式。由于某种原因,当<code>nth-of-type(odd)</code>嵌套在另一个div内时,它会影响到所有的div。以下是我对普通div和奇数个div的代码:</p>
<p>
<pre class="brush:css;toolbar:false;">.video-entry-summary {
width: 214px;
height: 210px;
margin-left: 10px;
float: left;
position: relative;
overflow: hidden;
border: 1px solid black;
}
.video-entry-summary:nth-of-type(odd) {
width: 214px;
height: 210px;
margin-left: 0px;
float: left;
position: relative;
overflow: hidden;
border: 1px solid black;
background: #ccc;
}</pre>
<pre class="brush:html;toolbar:false;"><div id="post-501" class="post-501 post type-post status-publish format-standard hentry category-moto-dz-films tag-news-sub-2">
<div class="video-entry-summary">
video 1
</div>
</div>
<div id="post-240" class="post-240 post type-post status-publish format-standard hentry category-videos">
<div class="video-entry-summary">
video 2
</div>
</div>
<div id="post-232" class="post-232 post type-post status-publish format-standard hentry category-videos">
<div class="video-entry-summary">
video 3
</div>
</div>
<div id="post-223" class="post-223 post type-post status-publish format-standard hentry category-videos">
<div class="video-entry-summary">
video 4
</div>
</div></pre>
</p>
<p>由于某种原因,当嵌套在div内时,<code>nth-of-type</code>不起作用,但是当它们不嵌套在任何div内时起作用。</p>
<p><strong>不嵌套在div内时的工作版本:</strong></p>
<p>
<pre class="brush:css;toolbar:false;">.video-entry-summary {
width: 214px;
height: 210px;
margin-left: 10px;
float: left;
position: relative;
overflow: hidden;
border: 1px solid black;
}
.video-entry-summary:nth-of-type(odd) {
width: 214px;
height: 210px;
margin-left: 0px;
float: left;
position: relative;
overflow: hidden;
border: 1px solid black;
background: #ccc;
}</pre>
<pre class="brush:html;toolbar:false;"><div class="video-entry-summary">
video 1
</div>
<div class="video-entry-summary">
video 2
</div>
<div class="video-entry-summary">
video 3
</div>
<div class="video-entry-summary">
video 4
</div></pre>
</p>
<p>如何使初始代码与上述代码相同?</p>
:nth-of-type()
和:nth-child()
类似,它们都必须来自同一个父元素。如果你需要这些包装的div
,请在这些包装上使用:nth-of-type()
:如果所有的兄弟元素都是
.post
,请使用:nth-child()
来避免与:nth-of-type()
的真正含义混淆: