AccueilDernières imagesRechercherS'enregistrerConnexion

Forum de graphisme, codage et game design proposant des tutoriels, astuces, libres services et commandes dans les domaines de l'infographie amateur, de l'intégration web (HTML et CSS essentiellement) ainsi que dans la conception de RPG sur forum.

Le deal à ne pas rater :
Manga Chainsaw Man : où acheter le Tome 17 édition Collector de ...
19.99 €
Voir le deal

    Principe du CSS : Les sélecteurs (Partie 1 : CSS2)

    Manumanu
    Manumanu
    MasculinAge : 36Messages : 71

    Mer 28 Aoû 2013 - 2:07

    Je ne traite ici que du CSS 2.1. Le CSS3 apporte de nouveaux sélecteurs très intéressants et utiles, mais je vais les traiter à part.

    Préambule


    Pour petit rappel :
    <balise attribut="valeur">


    Donc si vous êtes là, c'est que vous savez construire une feuille de style. Et vous travaillez comme ceci, grosso modo :
    Code:
    #page {
       width: 800px;
       overflow: auto;
    }

    #page .bloc {
       width: 100px;
       display: inline-block;
    }
    C'est une bonne base de travail ; mais désormais, nous allons voir l'utilisation plus avancée des sélecteurs. Figurez-vous que ceci veut dire quelque chose en CSS :

    Code:
    #page > div * div + div li:first-child a[href~="index.html"]  {
       color: #ccc;
    }
    Certes, c'est un tantinet plus long et complexe qu'écrire simplement la classe d'un élément.
    Il est important de noter que la séparation du contenu et de la mise en forme est au coeur même de l'utilisation du CSS et des principes sémantiques que le W3C met en place depuis des anneés (depuis la mise au point du xhtml). Par là même, l'idéal pour cette sémantique serait d'avoir un code html vide d'éléments de mise en forme - d'ailleurs, le W3C recommande l'absence de tout attribut style dans les balises html et préconise l'utilisation de classes et d'identifiants à la place.

    Mais on peut minimiser au maximum l'utilisation de ces classes et de ces ID grâce à l'utilisation des sélecteurs. Dans l'exemple ci-dessus, j'ai volontairement exagéré la complexité, mais on peut faire beaucoup de choses avec simplicité - parfois même plus qu'avec des classes.

    De plus, ça peut se révéler très utile dans certains cas. Songez à ceci :

    • Vous n'aurez peut-être pas toujours accès au html et donc pas la possibilité de le modifier. C'est le cas avec forumactif, par exemple.
    • Vous pouvez, grâce à ça, proposer un changement de design très facile, qui ne nécessite que peu de remaniement html sur votre site.
    • Cela sert également à appliquer un style à des éléments très nombreux sans avoir besoin de toucher au html.


    Les sélecteurs de descendance


    Sélecteur de descendance


     .rouge span { color: red }

    Vous utilisez déjà très probablement ce sélecteur, sans même le savoir. En effet, mettre un élément à la suite d'un autre crée automatiquement un principe de descendance. Dans le cas présent, la div portant la classe rouge devient parente de l'élément span qui lui, devient enfant.
    Dans cet exemple, toutes les balises span contenues dans la div seront affectés, et ce peu importe s'il y a d'autres balises entre eux ; sauf si un parent plus "proche" lui donne une information contradictoire, comme une autre couleur : c'est le principe d'héritage.
    Code:
    <div class="rouge">
       <div class="bleu">
          <span id="monID">Ce texte sera affecté</span>
       </div>
       <span>Ce texte sera affecté</span>
    </div>

    <span>Ce texte ne sera pas affecté</span>
    Dans le cas présent, le span portant l'id "monID" est enfant de la div "bleu", puis de la div "rouge". Voyons un petit schéma simple histoire de bien comprendre ce principe :
    • Mes enfants seront rouges
      • Mon parent m'a dit d'être rouge
      • Mon parent m'a dit d'être rouge
        • Le parent de mon parent m'a dit d'être rouge
        • Le parent de mon parent m'a dit d'être rouge
      • Mon parent m'a dit d'être rouge, mais mes enfants seront verts !
        • Mon parent m'a dit d'être vert
        • Mon parent m'a dit d'être vert
      • Mon parent m'a dit d'être rouge
    • Mes enfants seront bleus
      • Mon parent m'a dit d'être bleu

    Selecteur d'enfant direct : ">"


     .rouge > span { color: red }

    Sur le même principe de lien enfant/parent, ce sélecteur (qui ne porte pas de nom particulier au demeurant, mais que j'appelle "sélecteur d'enfant direct" pour être plus clair) sert à agir uniquement sur les enfants directs d'un élément, à l'inverse du sélecteur simple qui agit de manière récursive (c'est-à-dire sur toute sa descendance, y compris les descendants de ses descendants).
    Code:
    <div class="rouge">
       <div class="bleu">
          <span>Ce texte ne sera pas affecté</span>
       </div>

       <span>Ce texte sera affecté</span>
    </div>

    <span>Ce texte ne sera pas affecté</span>
    • Mes enfants directs seront rouges
      • Mon parent m'a dit d'être rouge
      • Mon parent m'a dit d'être rouge
        • On ne m'a rien dit
        • On ne m'a rien dit
      • Mon parent m'a dit d'être rouge

    Selecteur d'enfant indirect : "*"


     .rouge * span { color: red }

    À l'inverse du sélecteur d'enfant direct, ce sélecteur agit de manière inverse et affecte tous ses descendants sauf ses enfants directs.
    Code:
    <div class="rouge">
       <div class="bleu">
          <span>Ce texte sera affecté</span>
       </div>
       <span>Ce texte ne sera pas affecté</span>
    </div>
    <span>Ce texte ne sera pas affecté</span>
    • Mes enfants descendants seront rouges
      • On ne m'a rien dit
      • On ne m'a rien dit
        • Mon grand-parent m'a dit d'être rouge
        • Mon grand-parent m'a dit d'être rouge
        • Mon grand-parent m'a dit d'être rouge
          • Mon grand-parent m'a dit d'être rouge
          • Mon grand-parent m'a dit d'être rouge
      • On ne m'a rien dit

    Selecteur d'adjacence directe : "+"


     .rouge span + span { color: red }

    Un sélecteur un peu plus complexe cette fois-ci, mais très utile. Celui-ci sert à définir un lien d'adjacence entre deux balises ayant un parent direct commun. Les éléments adjacents au dernier cité ne seront pas affectés.
    Code:
    <div class="rouge">
       <div class="bleu">
          <span>Ce texte ne sera pas affecté</span>
          <span>Ce texte sera affecté</span>
       </div>

       <span>Ce texte ne sera pas affecté</span>
       <span>Ce texte sera affecté</span>
    </div>
    <span>Ce texte ne sera pas affecté</span>
    • Je n'ai rien dit à personne
      • Mes frères seront rouges !
      • Mon frère m'a dit d'être rouge
      • Mon frère m'a dit d'être rouge
    On peut bien sûr utiliser ce sélecteur plusieurs fois. Par exemple, si on voulait affecter les éléments d'une liste seulement à partir du quatrième élément :
     li+li+li+li { color: red }

    1. Élément de liste
    2. Élément de liste
    3. Élément de liste
    4. Élément de liste
    5. Élément de liste
    6. Élément de liste
    7. Élément de liste
    8. Élément de liste
    9. Élément de liste
    C'est un sélecteur dont je me sers régulièrement pour, entre autres, définir des marges automatiques entre deux éléments de même nature, comme des blocs d'un élément de menu.
    #sidebar div+div { margin-top: 15px }


    Les sélecteurs d'attributs


    On peut également attribuer des propriétés à un (ou plusieurs) élément(s) html précis en fonction des attributs qu'ils portent. Ainsi on peut, encore une fois, se passer facilement d'ajouts de classes dans le html en se reposant sur ce qui existe déjà. Il suffit d'accoler le nom de l'attribut en question entre crochets [] à l'élément en question. On ne se soucie pas de la valeur de cet attribut.
    a[title] { color: red }

    Code:

    <a href="#">Ce lien ne sera pas affecté</a>
    <a href="#" title="">Ce lien sera affecté</a>
    <a href="#" title="Venez sur mon site !">Ce lien sera affecté</a>
    a[target] { color: red }

    Code:

    <a href="#">Ce lien ne sera pas affecté</a>
    <a href="#" title="">Ce lien ne sera pas affecté</a>
    <a href="#" title="" target="">Ce lien sera affecté</a>
    Mais on peut également aller plus loin et cibler un élément dont l'attribut prend une valeur précise. C'est très utile pour les éléments d'un formulaire, qui sont définis, avec la même balise, par la valeur de leur type :
    input[type=password] { color: red }

    Code:
    <input type="text" />
    <input type="password" /> <!-- Cet élément sera affecté -->
    <input type="submit" />
    Vous pouvez également définir le fait qu'un attribut doit contenir au moins une des valeurs énoncées.
    a[rel~=copyright] { color: red }

    Code:
    <a href="#" rel="">Ce lien ne sera pas affecté</a>
    <a href="#" rel="copyright">Ce lien sera affecté</a>
    <a href="#" rel="copyright copyleft">Ce lien sera affecté</a>
    Sachez enfin qu'on peut combiner ces sélecteurs à volonté :
    a[rel][target=_blank][title] { color: red }


    Les pseudo-classes



    Les pseudo-classes désignent des éléments que l'on n'aurait pas pu cibler sans ajouter une classe particulière.

    :first-child


    Très pratique dans certains cas, cette pseudo-classe cible un élément s'il est le premier enfant de son parent. Il faut donc bien faire attention, car il s'agit bien du premier enfant, et non du premier enfant d'un tel type. Par exemple :
    div p:first-child { color: red }

    Code:
    <div>
       <p>Cet élément sera affecté</p>
       <p>Cet élément ne sera pas affecté</p>
       <p>Cet élément ne sera pas affecté</p>
    </div>
    Si on voit maintenant, pour le même code CSS, ce code HTML :
    Code:
    <div>
       <h2>Ce titre ne sera pas affecté</h2>
       <p>Cet élément ne sera pas affecté</p>
       <p>Cet élément ne sera pas affecté</p>
       <p>Cet élément ne sera pas affecté</p>
    </div>
    Rien ne va se passer. En effet, le code CSS signifie "cibler tous les éléments p s'il s'agit du premier enfant de leur parent" et non "cibler tous les éléments p qui sont les premiers de ces éléments de type p enfants". Or dans ce cas, c'est h2 qui est le premier enfant.

    :active


    Cette pseudo-classe est de moins en moins utilisée. Elle est héritée de la première version du CSS et servait à cibler un lien "actif" (donc un lien au moment où il était cliqué). On peut maintenant l'utiliser sur n'importe quel élément, mais c'est assez peu usité.
    a:active { color: white }


    :link


    Cette pseudo-classe est de moins en moins utilisée. Elle sert à cibler un lien qui n'a pas encore été visité par le visiteur actuel.
    a:link { color: white }


    :visited


    Cette pseudo-classe est de moins en moins utilisée. À l'inverse du précédent, elle sert à cibler un lien qui a déjà été visité par le visiteur actuel.
    a:visited { color: violet }


    :focus


    Cette pseudo-classe permet de cibler un élément qui a actuellement le "focus". Par exemple, lorsque vous cliquez dans un champ de texte, celui-ci prend automatiquement cette valeur dynamique de focus. C'est aussi le cas des liens, lorsqu'on navigue avec la touche "tab".
    input:focus { background: green }


    :hover


    Cette pseudo-classe est très utilisée. Elle déclenche un ensemble de propriétés au survol d'un élément par la souris. C'est par exemple très utilisé pour les menus, qui vont se dérouler ou changer de couleur au survol. On peut l'appliquer à tout élément html.
    div:hover { background: white }


    Il est aussi possible de cibler des éléments au survol de leur parent. Dans le cas suivant, ce sont tous les liens contenus dans un élément de liste, au survol de la div qui les contient (et non au survol du lien) :
    div:hover li a { background: white }


    Les pseudo-éléments



    Les pseudo-éléments s'utilisent de la même manière que les pseudo-classes ; cette appellation désigne simplement des éléments que l'on n'aurait pas pu identifier sans ajouter un autre élément (comme span ou div, par exemple).

    :first-letter


    On peut se servir de :first-letter pour créer des lettrines. C'est d'ailleurs sa principale utilité. Dans l'exemple suivant, tous les éléments p verront leur première lettre affichée en rouge.
    p:first-letter { color: red }


    :first-line


    Peu utilisé, ce pseudo-élément va agir sur la première ligne de texte d'un élément.
    p:first-line { color: red }


    :after et :before


    Voici deux pseudo-éléments complémentaires très utiles. Ils s'utilisent avec la propriété content et servent à rajouter un élément avant (pour :before) ou après (pour :after) un autre élément.
    span:before{ content: "→ " }

    Ainsi pour ce code :
    Code:
    <span>Test</span>
    On obtiendra ce résultat :
    → Test
    a:after{ content: " >>" }

    Code:
    <a href="#">Lien</a>

    Le sélecteur universel : " * "


    Ce sélecteur, à ne pas confondre avec le sélecteur d'enfant indirect que nous avons vu plus haut, cible tous les éléments.
    * { color: red }


    Ce sélecteur est donc très lourd à utiliser et vous ne devriez l'employer qu'avec une extrême parcimonie, voire jamais !




    N'hésitez pas si vous avez des questions.



    Eh.
    Neva
    Neva
    FémininAge : 32Messages : 18565

    Mer 28 Aoû 2013 - 15:21

    Merci pour ce tuto !  :)
    En plus, les sélecteurs permettent de régler certains problèmes avec les templates et les gens y pensent malheureusement pas assez souvent (ou ne connaissent pas, je ne sais pas)



     
    Manumanu
    Manumanu
    MasculinAge : 36Messages : 71

    Mer 28 Aoû 2013 - 16:41

    Il y a une grande méconnaissance du CSS, et dans le web en général, du fait de son accessibilité. Donc oui, beaucoup ne connaissent pas. Comme dirait Léa Verou : "CSS is easy to learn, but hard to master".



    Eh.
    Offrande
    Offrande
    FémininAge : 32Messages : 194

    Sam 14 Sep 2013 - 0:15

    +1 ! Merci beaucoup pour ce topic magnifique! 
    Je travail beaucoup avec le CSS basique et CSS3 mais je n'avais jamais entendus parler de ce mode de rédaction de code. Très intéressant.

    J'attend la suite avec impatience! :kdo:
    Sparrow-style
    Sparrow-style
    FémininAge : 39Messages : 32055

    Mer 10 Sep 2014 - 12:55

    En effet c'est quelque chose que je n'utilise pas assez souvent (mais de plus en plus souvent tout de même^^) donc il faudra que je lise ces deux tuto' avec application x)

    Je les déplace tout deux dans la section tutoriels du coup. Merci !



    sign
    Manumanu
    Manumanu
    MasculinAge : 36Messages : 71

    Mer 10 Sep 2014 - 17:15

    À noter cependant : C'est très pratique pour composer avec un code html sur lequel on n'a pas forcément la main mise, mais aujourd'hui les "bonnes pratiques" vont plutôt vers la déclarations de classes uniques. À utiliser avec parcimonie, donc. Wink

    C'est relativement pratique, par exemple, pour mettre un espace entre plusieurs éléments :

    Code:
    <div class="machin">test</div>
    <div class="machin">test</div>
    <div class="machin">test</div>

    Code:
    .machin + .machin { margin-top: 20px }

    Comme ça, il n'y a 20px qu'entre les éléments, et non avant ou après chaque.



    Eh.
    Nihil Scar Winspeare
    Nihil Scar Winspeare
    Messages : 5244

    Jeu 22 Jan 2015 - 23:15

    Merci pour ton partage Manu :p

    Je pensais à rajouter une petite chose pour les pseudo éléments before et after, ils ne peuvent pas s'appliquer sur les balises orphelines (img, input, br, etc).
    Ainsi on ne peut pas mettre de sélecteur comme img:before ou encore br:after ^-^

    alsayed
    alsayed
    MasculinAge : 50Messages : 75

    Dim 21 Mai 2017 - 9:49

    Merci
    Contenu sponsorisé


      La date/heure actuelle est Jeu 28 Mar 2024 - 20:17