Sommaire partiellement masqué - faites défiler !
Vous pouvez me contacter via Facebook pour questions & suggestions :
Page Facebook relative à mon site
La notion de sélecteur est vraiment centrale dans jQuery !
Dans les chapitres précédents au travers des exemples vous avez vu déjà de nombreux sélecteurs.
Vous avez du vous dire :" Mais c'est comme les sélecteurs CSS !
Exemple de sélecteur | Eléments de la page sélectionnés |
---|---|
* | Sélectionne toutes les balises |
h1 | Sélectionne toutes les balises h1 |
h1,h2,h3 | Sélectionne toutes les balises h1, h2 et h3 |
ul li | Sélectionne toutes les balises LI contenues dans UL |
ul>li | Sélectionne les LI "enfants" (descendants directs) de Ul |
ul+li | Sélectionne la balise LI qui suit immédiatement UL (premier item) |
#titre | Sélectionne la balise ayant l'attribut id ="titre" |
.remarque | Sélectionne les balises ayant l'attribut class ="remarque" |
img[alt] | Sélectionne les images ayant l'attribut alt |
Pour construire les sélecteurs jQuery on ne peut pas utiliser certaines pseudo-classes de CSS !
hover existe en jQuery mais il s'agit d'une méthode (et non pas d'un pseudo classe événementielle).
Vous n'avez pas le droit d'écrire en jQuery par exemple : $("a:hover") vous devez écrire : $("a").hover(... )
Vous pouvez bâtir des sélecteurs jQuery à partir des pseudo-classes ci-dessous.
pseudo-classe | fonction |
---|---|
:hidden | sélectionne les éléments cachés |
:visible | sélectionne les éléments visibles |
:empty | sélectionne les éléments vides |
:parent | sélectionne les éléments qui ont au moins un enfant |
:header | sélectionne les balises titres (h1 à h6) |
:first | sélectionne le premier élément |
:last | sélectionne le dernier élément |
:eq(n) | sélectionne l'élément d'indice n |
:gt(n) | sélectionne les élements dont l'indice est supérieur à n (gt acronyme de : greather than) |
:lt(n) | sélectionne les élements dont l'indice est inférieur à n (lt acronyme de : less than) |
:even | sélectionne les élements pairs |
:odd | sélectionne les élements impairs |
:not | pseudo-classe utilisée pour désigner une négation |
:has(selecteur) | sélectionne les éléments qui ont comme descendant le sélecteur indiqué |
:contains(chaîne) | sélectionne les éléments dont le texte contient la chaîne indiquée |
Vous que vous compreniez pas très bien pour le moment l'intérêt des certains de ces pseudo-classes est normale.
Rien ne vaut des exemples de sélecteurs construits à partir de ces pseudo-classes.
Exemple de sélecteur | Eléments de la page sélectionnés |
---|---|
img:hidden | Sélectionne les images cachées |
img:visible | Sélectionne les images visibles |
p:empty | Sélectionne les balises P sans contenu |
p:parent | Sélectionne les balises P avec contenu |
#corps:header | Sélectionne les balises titre (h1 à h6) dans la boîte identifiée "corps" |
li:first | Sélectionne le premier item de chaque liste |
ul li:last | Sélectionne le dernier item de chaque liste à puces |
button:eq(1) | Sélectionne le bouton d'indice 1 ; donc le deuxième |
li:gt(1) | Sélectionne les items de listes dont l'indice est supérieur à 1 (gt: greather than) |
tr:lt(2) | Sélectionne les lignes des tableaux dont l'indice est inférieur à 2 (lt: less than) |
tr:even | Sélectionne les lignes paires dans tous les tableaux |
#premier tr:odd | Sélectionne les lignes impaires du tableau identifié "premier" |
li:not(first) | Sélectionne tous les items de liste sauf le premier item de chaque liste |
p:has(i) | Sélectionne les paragraphes dont le texte est en italique (balise i) |
p:contains("javascript") | Sélectionne les paragraphes dont le texte contient la chaîne "javascript" |
Il seront évoqué dans le chapitre "jQuery et les formulaires".
Dans cette page une fonction jQuery qui fait fonction de feuille de style qui est exécutée automatiquement au chargement de la page.
Lorsque vous survolez une image elle devient opaque le temps du survol.
La couleur de fond d'une ligne de tableau devient grise le temps du survol.
Remarquez que j'utilise le gestionnaire d'évènements de HTML.
Les deux dernières images sont masquées. !
La fonction finfos montre que l'on peut utiliser la propriété length pour connaître le nombre d'éléments sélectionnées via un sélecteur JQuery.
Les deux dernières instructions sont nouvelles. Etudiez les attentivement.
Elles sont basées sur l'événement hover !
Traduisons en Français ces instructions !
Première instruction : si survol d'une image cette dernière devient opaque ; dès la fin du survol elle redevient transparente.
Seconde instruction : si survol d'une ligne de tableau celle-ci prend un fond gris ; dès la fin du survol le fond redevient
blanc.
Un instruction utilisant l'événement hover remplace deux instructions : l'une basée sur l'événement mousevover et l'autre sur l'événement mouseout.
En effet l'événement hover est suivi non pas d'une mais de deux fonctions ! La première est exécutée lors du
survol (mouseover) et la seconde dès que le survol cesse (mouseout).
Il s'agit donc là encore d'une technique pour simplifier au maximum le code afin de respecter le slogan de Jquery : "Write less, do more !"
Le rendu dans un cadre :
Attention $("img:hidden").length retourne 1 alors qu'il y a deux images masquées l'une avec display:none et l'autre avec visibility :hidden. En effet un élément HTML affecté de la propriété visibility:hidden (ou opacity :0) n'est pas considéré comme masqué par jQuery car il consomme encore de la place dans la mise en page (à la différence de display:none).