Mengapakah pemilih ke-nth-of-type/nth-child tidak mempunyai kesan pada elemen bersarang?
P粉237689596
2023-08-24 16:07:18
<p>Saya cuba menukar gaya bilangan ganjil div yang bersarang dalam satu div. Atas sebab tertentu, apabila <code>nth-of-type(odd)</code> bersarang di dalam div lain, ia mempengaruhi semua div. Berikut ialah kod saya untuk div biasa dan bilangan div yang ganjil: </p>
<p>
<pre class="brush:css;toolbar:false;">.video-entry-summary {
lebar: 214px;
ketinggian: 210px;
jidar-kiri: 10px;
terapung: kiri;
kedudukan: relatif;
limpahan: tersembunyi;
sempadan: 1px hitam pejal;
}
.video-entry-summary:nth-of-type(odd) {
lebar: 214px;
ketinggian: 210px;
jidar-kiri: 0px;
terapung: kiri;
kedudukan: relatif;
limpahan: tersembunyi;
sempadan: 1px hitam pejal;
latar belakang: #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- filem tag-berita-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>Atas sebab tertentu, <kod>jenis-jenis</kod> tidak berfungsi apabila bersarang di dalam div, tetapi berfungsi apabila ia tidak bersarang di dalam mana-mana div. </p>
<p><strong>Versi berfungsi apabila tidak bersarang dalam div: </strong></p>
<p>
<pre class="brush:css;toolbar:false;">.video-entry-summary {
lebar: 214px;
ketinggian: 210px;
jidar-kiri: 10px;
terapung: kiri;
kedudukan: relatif;
limpahan: tersembunyi;
sempadan: 1px hitam pejal;
}
.video-entry-summary:nth-of-type(odd) {
lebar: 214px;
ketinggian: 210px;
jidar-kiri: 0px;
terapung: kiri;
kedudukan: relatif;
limpahan: tersembunyi;
sempadan: 1px hitam pejal;
latar belakang: #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>Bagaimanakah saya boleh membuat kod awal sama seperti di atas? </p>
:nth-of-type()
和:nth-child()
类似,它们都必须来自同一个父元素。如果你需要这些包装的div
,请在这些包装上使用:nth-of-type()
:Jika semua unsur adik beradik adalah maksud sebenar
.post
,请使用:nth-child()
来避免与:nth-of-type()
Mengelirukan: