Existe-t-il un moyen de sélectionner chaque nième élément enfant qui satisfait (ou ne satisfait pas) un sélecteur arbitraire ? Par exemple, je souhaite sélectionner chaque ligne impaire du tableau, mais dans un sous-ensemble de lignes :
table.myClass tr.row:nth-child(impair) { ... } ≪/pré>
Ligne |
Ligne |
Ligne |
Ligne ≪/pré> Mais Quelqu’un peut-il expliquer pourquoi ?
Sujets populaires
Plus>
Articles populaires
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
|
Ce n'est pas vrai..
Citation de la documentation
Il s'agit d'un sélecteur autonome, non combiné avec une classe. Dans votre règle, il suffit de satisfaire les deux sélecteurs, donc si
:nth-child(even)
表格行也有.row
classe, cela se verra.C'est une question très courante qui découle d'une incompréhension du fonctionnement de
:nth-child(An+B)
和:nth-of-type()
.Dans le sélecteur de niveau 3, la
:nth-child()
pseudo-classecalcule la position parmi tous les frères et sœurs sous le même élément parent, pas seulement ceux qui correspondent au reste du sélecteur.De même, la
:nth-of-type()
pseudo-classecompte les frères et sœurs avec lesquels elle partage le même type d'élément, qui en HTML est la signature de l'indicateur, pas le reste du sélecteur.Cela signifie également que si tous les éléments enfants du même élément parent sont du même type d'élément, par exemple un corps de table avec seulement
ettr
元素或列表元素只有li
元素,那么:nth-child()
和:nth-of-type()
的行为将是相同的,即对于每个An+B的值,:nth-child(An+B)
和:nth-of-type(An+B)
éléments ou un élément de liste avec uniquement des élémentsli
, alors le comportement deseront identiques, c'est-à-dire que pour chaque valeur de An+B,
sous-ensemble:nth-child(An+B)
et:nth-of-type(An+B)
correspondra de la même manière à un ensemble d'éléments.:nth-child()
和:not()
En fait, tous les sélecteurs simples au sein d'un sélecteur composé donné, y compriset les pseudo-classes telles que:not()
, fonctionnentindépendammentplutôt que d'être visualisés par le sélecteur. Le reste de la correspondanceéléments.Cela signifie égalementqu'au sein de chaque sélecteur composé individuel, il n'y a aucune notion d'ordre entre les sélecteurs simples
1, ce qui signifie que par exemple les deux sélecteurs suivants sont équivalents :
Traduits en anglais, ils signifient tous :
(Vous remarquerez que j'ai utilisé une liste non ordonnée ici, juste pour souligner ce point)
2:nth-child(An+B of S)
Selector niveau 4 tente de corriger cette limitation en permettant àd'accepter des arguments de sélecteur arbitraires S, en raison du fonctionnement indépendant des sélecteurs au sein des sélecteurs composés, tel que déterminé par la syntaxe du sélecteur existant. Donc dans votre cas, cela ressemblerait à ceci :
Bien sûr, en tant que proposition complètement nouvelle dans une spécification complètement nouvelle, cela ne sera peut-être pas mis en œuvre avant ans.
En attendant, vous devrez utiliser un script pour filtrer les éléments et appliquer des styles ou des noms de classes supplémentaires en conséquence. Par exemple, voici une solution de contournement courante utilisant jQuery (en supposant qu'il n'y ait qu'un seul groupe de lignes dans le tableau contenant l'élémenttr
) :
Le CSS correspondant pourest :
Si vous utilisez un outil de test automatisé comme Selenium, ou un outil comme BeautifulSoup pour analyser le HTML, beaucoup de ces outils permettent l'utilisation de XPath comme alternative :
D'autres solutions utilisant des techniques différentes sont laissées en exercice au lecteur ; il ne s'agit que d'un exemple bref et délibéré.1Si un sélecteur de type ou universel est spécifié, il doit venir en premier. Cependant, cela ne change pas le fonctionnement de base des sélecteurs ; c'est juste une bizarrerie de syntaxe.
2a été initialement proposé comme une extension de
:nth-match()
,然而,因为它仍然只计算相对于其同级元素,而不是与满足给定选择器的每个其他元素,所以自2014年以来,它已被重新用作现有的:nth-child()
.