Maison > interface Web > tutoriel CSS > Explication détaillée de la différence entre le nième-enfant et le nième-de-type en CSS3

Explication détaillée de la différence entre le nième-enfant et le nième-de-type en CSS3

黄舟
Libérer: 2017-06-01 10:41:29
original
1789 Les gens l'ont consulté

La différence entre nth-child et nth-of-type en CSS3 est en fait très simple : Pourquoi :nth-of-type est-il appelé :nth-of-type ? Parce qu'il se distingue par "type". C'est-à-dire : ele:nth-of-type(n) fait référence au nième élément ele sous l'élément parent, et ele:nth-child(n) fait référence au nième élément sous l'élément parent et cet élément est ele. Si ce n'est pas le cas, la sélection échoue.

Le texte peut paraître plutôt obscur, il est donc plus facile à comprendre :

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>demo</title>
</head>
<style>
.demo li:nth-child(2){
color: #ff0000;
}
.demo li:nth-of-type(2){
color: #00ff00;
}
</style>
<body>
<p>
<ul class="demo">
<p>zero</p>
<li>one</li>
<li>two</li>
</ul>
</p>
</body>
</html>
Copier après la connexion


Le résultat est le suivant :

Explication détaillée de la différence entre le nième-enfant et le nième-de-type en CSS3

Dans l'exemple ci-dessus, .demo li:nth-child(2) sélectionne le nœud

  • one
  • (2) sélectionne le nœud
  • two


  • Mais que se passe-t-il si aucune balise n'est spécifiée avant nième enfant et nième de type ?

    .demo :nth-child(2){
    color: #ff0000;
    }
    .demo :nth-of-type(2){
    color: #00ff00;
    }
    Copier après la connexion


    Quel sera le résultat ? Regardez la structure html :

    <ul class="demo">
    <p>first p</p>
    <li>first li</li>
    <li>second li</li>
    <p>second p</p>
    </ul>
    Copier après la connexion


    Résultat :

    Explication détaillée de la différence entre le nième-enfant et le nième-de-type en CSS3

    Comme on peut le voir ci-dessus, le type de balise n'est pas spécifié avant eux, :nth-child(2) sélectionne le deuxième élément, quelle que soit la balise dont il s'agit. Et :nth-type-of(2) sélectionne deux éléments, qui sont la deuxième balise p et la deuxième balise li dans parent.demo. On peut voir que lorsque le type de balise n'est pas spécifié, :nth-type -of. (2) sélectionnera la deuxième de toutes les balises de type.

    Nous avons déjà compris l'usage de base et les différences entre nième-enfant et nième-de-type, allons donc plus loin dans nième-de-type(n) et nième-enfant( n) Qu'est-ce que n ?

    n dans nième-de-type(n) et nième-enfant(n) peut être un nombre, un mot-clé ou une formule. Chiffres : il s’agit de l’utilisation des exemples ci-dessus, je n’entrerai donc pas dans les détails. Mots-clés : Impair, pair

    Pair et impair sont des mots-clés qui peuvent être utilisés pour faire correspondre des sous-éléments dont l'indice est impair ou pair est 1

    Ici, nous spécifions deux couleurs d'arrière-plan différentes. pour les p éléments impairs et pairs :


    Formule : Ou arithmétique

    L'expression
    p:nth-of-type(odd)
    {
    background:#ff0000;
    }
    p:nth-of-type(even)
    {
    background:#0000ff;
    }
    Copier après la connexion

    utilise la formule (an + b). Description : indique la durée de la période, n est le compteur (à partir de 0) et b est la valeur de décalage.
    Ici, nous spécifions la couleur d'arrière-plan de tous les p éléments dont les indices sont des multiples de 3 :



    Si : nième-de-type(4n+2) Sélectionnez simplement tous les éléments dont les indices sont des multiples de 4 plus 2

    p:nth-of-type(3n+0)
    {
    background:#ff0000;
    }
    Copier après la connexion

    Résumé




    -->

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Étiquettes associées:
    source:php.cn
    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
    Tutoriels populaires
    Plus>
    Derniers téléchargements
    Plus>
    effets Web
    Code source du site Web
    Matériel du site Web
    Modèle frontal