Maison > interface Web > tutoriel CSS > Sélecteur de descendant CSS

Sélecteur de descendant CSS

php中世界最好的语言
Libérer: 2018-03-20 15:22:02
original
3839 Les gens l'ont consulté

Cette fois, je vous apporte le sélecteur de descendant CSS. Quelles sont les précautions lors de l'utilisation du sélecteur de descendant CSS. Voici un cas pratique, jetons un oeil.

Le sélecteur de descendants est utilisé pour sélectionner tous les descendants d'une balise, y compris les enfants et petits-enfants, etc. ; tandis que le sélecteur de descendants sélectionne uniquement les balises descendantes du parent spécifié (les éléments enfants de première génération de la balise spécifiée élément) .

Le sélecteur descendant utilise un symbole supplémentaire (crochets > ) pour indiquer la relation entre deux éléments.

Par exemple : body>h1 sélectionne toutes les balises

de première génération dans la balise

Diagramme de relation de la balise HTML

Code HTML

<h1>body里面的h1标题</h1>
<p>
    <h2>p里面的h2</h2>
    <p>
        p里面的p标签,p标签里面有一个<strong><a href="#">加粗的链接</a></strong>
    </p>
</p>
<h2>body里面的h2标题</h2>
<ul>
    <li>列表1
        <ul>
            <li>小列表a</li>
            <li>小列表b</li>
            <li>小列表c</li>
        </ul>
    </li>
    <li>
        <a href="#">列表2(带链接)</a>
    </li>
    <li>
        <a href="#">列表3(带链接)</a>
    </li>
</ul>
Copier après la connexion

Après avoir compris la structure ci-dessus, vous pouvez essayer le code suivant :

Code CSS

body>h2 {
    color: orange;
}
Copier après la connexion

Dans le code HTML ci-dessus, un total de Il y a 2 balises

, mais n'a qu'un seul descendant de

, et l'autre

est à l'intérieur de

, donc le code CSS ci-dessus s'applique uniquement au la première balise

Ce qui suit est un sélecteur d'enfant plus intéressant

 : premier enfant

Sélectionnez la première sous-balise.

Code CSS

h2:first-child {
    color: orange;
}
Copier après la connexion

La fonction de ce sélecteur est : recherchez d'abord toutes les balises

;h2> recherchez son élément parent, puis déterminez si la balise

est classée en premier dans son élément parent.

Ici, étant donné que la première balise de est

, l'élément enfant

Parce que

dans

est le premier élément enfant de

, donc le

dans

:last-child

Ce sélecteur est similaire au sélecteur :first-child, mais il sélectionne le dernier enfant d'un élément.

Code CSS

li:last-child {
    font-size: 2em;
}
Copier après la connexion

Comme vous pouvez le constater, les tailles de police de la "Petite Liste C" et de la "Liste 3 (avec lien)" ont devenir plus grand. Parce que ces deux éléments sont les derniers éléments spécifiés.

:only-child

Sélectionnez l'enfant unique d'un élément.

Code HTML

<p>
    <p>第一个p的p</p>
</p>
<p>
    <p>第二个p的第一个p</p>
    <a href="#">第二个p的第一个a</a>
</p>
Copier après la connexion

Code CSS

p:only-child {
    color: orange;
}
Copier après la connexion

Le style ci-dessus s'applique uniquement au premier

;p>Élément. Puisqu'il n'y a pas seulement des éléments

dans le deuxième

, mais également un élément , l'élément

du deuxième

Ce sélecteur est difficile à comprendre. Le style défini par ce sélecteur n'est efficace que si la balise spécifiée est la seule descendante d'une autre balise. En d'autres termes, ce n'est pas suffisant s'il n'y a qu'une seule balise spécifiée dans le descendant. Si la balise spécifiée a d'autres balises sœurs, le style défini par ce sélecteur sera invalide.

:ntième-enfant

Ce sélecteur est plus compliqué à utiliser, mais il est aussi particulièrement utile.

Ce sélecteur peut facilement définir des styles pour les lignes d'un tableau, les éléments séparés par deux éléments dans une liste ou un autre nombre d'éléments descendants.

Ce sélecteur nécessite une valeur pour déterminer quels descendants sont sélectionnés.

Les valeurs les plus simples sont les mots-clés, à savoir impairs et pairs.

  1. odd用于选取奇数子代元素。

  2. even用于选取偶数子代元素。

HTML代码

<ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
    <li>7</li>
</ul>
Copier après la connexion
Copier après la connexion

CSS代码

li:nth-child(odd) {
    background: pink;
}
li:nth-child(even) {
    background: teal;
}
Copier après la connexion

第一个子元素的下标是 1。

需要注意的是,如果在第一个

  • 之前还有其他元素,那第一个
  • 的下标就不是1了。
    比如

    HTML代码

    <ul>
        <a href="#">a</a>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
    </ul>
    Copier après la connexion
    Copier après la connexion

    这时的效果是

    li:nth-child(odd) 的意思是找到

  • 元素的父元素,通过父元素来检测每一个
  • 的下标的奇偶。

    因为

  • É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