jQuery - Sélecteurs
La bibliothèque jQuery exploite la puissance des sélecteurs de feuilles de style en cascade (CSS) pour nous permettre d'accéder rapidement et facilement à des éléments ou à des groupes d'éléments dans le modèle d'objet de document (DOM).
Un sélecteur jQuery est une fonction qui utilise des expressions pour trouver les éléments correspondants d'un DOM en fonction des critères donnés. Vous pouvez simplement dire que les sélecteurs sont utilisés pour sélectionner un ou plusieurs éléments HTML à l'aide de jQuery. Une fois qu'un élément est sélectionné, nous pouvons effectuer diverses opérations sur cet élément sélectionné.
La fonction d'usine $ ()
Les sélecteurs jQuery commencent par le signe dollar et les parenthèses - $(). La fonction d'usine$() utilise les trois blocs de construction suivants lors de la sélection des éléments dans un document donné -
N ° Sr. | Sélecteur et description |
---|---|
1 |
Tag Name Représente un nom de balise disponible dans le DOM. Par exemple$('p') sélectionne tous les paragraphes <p> du document. |
2 |
Tag ID Représente une balise disponible avec l'ID donné dans le DOM. Par exemple$('#some-id') sélectionne l'élément unique dans le document qui a un ID de some-id. |
3 |
Tag Class Représente une balise disponible avec la classe donnée dans le DOM. Par exemple$('.some-class') sélectionne tous les éléments du document qui ont une classe d'une certaine classe. |
Tous les éléments ci-dessus peuvent être utilisés seuls ou en combinaison avec d'autres sélecteurs. Tous les sélecteurs jQuery sont basés sur le même principe à l'exception de quelques ajustements.
NOTE - La fonction d'usine $() est synonyme de jQuery()fonction. Donc, si vous utilisez une autre bibliothèque JavaScript où$ le signe est en conflit avec quelque chose d'autre alors vous pouvez remplacer $ signer par jQuery nom et vous pouvez utiliser la fonction jQuery() au lieu de $().
Exemple
Voici un exemple simple qui utilise Tag Selector. Cela sélectionnerait tous les éléments avec un nom de balisep.
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("p").css("background-color", "yellow");
});
</script>
</head>
<body>
<div>
<p class = "myclass">This is a paragraph.</p>
<p id = "myid">This is second paragraph.</p>
<p>This is third paragraph.</p>
</div>
</body>
</html>
Cela produira le résultat suivant -
Comment utiliser les sélecteurs?
Les sélecteurs sont très utiles et seraient nécessaires à chaque étape lors de l'utilisation de jQuery. Ils obtiennent l'élément exact que vous souhaitez de votre document HTML.
Le tableau suivant répertorie quelques sélecteurs de base et les explique avec des exemples.
N ° Sr. | Sélecteur et description |
---|---|
1 |
Nom
Sélectionne tous les éléments qui correspondent à l'élément donné Name. |
2 | #ID
Sélectionne un seul élément qui correspond à la donnée ID. |
3 | .Classe
Sélectionne tous les éléments qui correspondent à la donnée Class. |
4 | Universel (*)
Sélectionne tous les éléments disponibles dans un DOM. |
5 | Éléments multiples E, F, G
Sélectionne les résultats combinés de tous les sélecteurs spécifiés E, F ou G. |
Exemples de sélecteurs
Semblable à la syntaxe et aux exemples ci-dessus, les exemples suivants vous permettront de comprendre comment utiliser différents types d'autres sélecteurs utiles -
N ° Sr. | Sélecteur et description |
---|---|
1 | $('*') Ce sélecteur sélectionne tous les éléments du document. |
2 | $("p > *") Ce sélecteur sélectionne tous les éléments qui sont les enfants d'un élément de paragraphe. |
3 | $("#specialID") Cette fonction de sélection récupère l'élément avec id = "specialID". |
4 | $(".specialClass") Ce sélecteur récupère tous les éléments qui ont la classe specialClass . |
5 | $("li:not(.myclass)") Sélectionne tous les éléments correspondant à <li> qui n'ont pas class = "myclass". |
6 | $("a#specialID.specialClass") Ce sélecteur fait correspondre les liens avec un identifiant de specialID et une classe de specialClass . |
sept | $("p a.specialClass") Ce sélecteur fait correspondre les liens avec une classe de specialClass déclarée dans les éléments <p>. |
8 | $("ul li:first") Ce sélecteur obtient uniquement le premier élément <li> du <ul>. |
9 | $("#container p") Sélectionne tous les éléments correspondant à <p> qui sont les descendants d'un élément qui a un identifiant de conteneur . |
dix | $("li > ul") Sélectionne tous les éléments correspondant à <ul> qui sont les enfants d'un élément correspondant à <li> |
11 | $("strong + em") Sélectionne tous les éléments correspondant à <em> qui suivent immédiatement un élément frère correspondant à <strong>. |
12 | $("p ~ ul") Sélectionne tous les éléments correspondant à <ul> qui suivent un élément frère correspondant à <p>. |
13 | $("code, em, strong") Sélectionne tous les éléments correspondant à <code> ou <em> ou <strong>. |
14 | $("p strong, .myclass") Sélectionne tous les éléments correspondant à <strong> qui sont les descendants d'un élément correspondant à <p> ainsi que tous les éléments qui ont une classe de myclass . |
15 | $(":empty") Sélectionne tous les éléments qui n'ont pas d'enfants. |
16 | $("p:empty") Sélectionne tous les éléments correspondant à <p> qui n'ont pas d'enfants. |
17 | $("div[p]") Sélectionne tous les éléments correspondant à <div> qui contiennent un élément correspondant à <p>. |
18 | $("p[.myclass]") Sélectionne tous les éléments correspondant à <p> qui contiennent un élément avec une classe de myclass . |
19 | $("a[@rel]") Sélectionne tous les éléments correspondant à <a> qui ont un attribut rel. |
20 | $("input[@name = myname]") Sélectionne tous les éléments correspondant à <input> qui ont une valeur de nom exactement égale à myname. |
21 | $("input[@name^=myname]") Sélectionne tous les éléments correspondant à <input> qui ont une valeur de nom commençant par myname . |
22 | $("a[@rel$=self]") Sélectionne tous les éléments correspondant à <a> qui ont relvaleur d'attribut se terminant par self . |
23 | $("a[@href*=domain.com]") Sélectionne tous les éléments correspondant à <a> qui ont une valeur href contenant domain.com. |
24 | $("li:even") Sélectionne tous les éléments correspondant à <li> qui ont une valeur d'index paire. |
25 | $("tr:odd") Sélectionne tous les éléments correspondant à <tr> qui ont une valeur d'index impaire. |
26 | $("li:first") Sélectionne le premier élément <li>. |
27 | $("li:last") Sélectionne le dernier élément <li>. |
28 | $("li:visible") Sélectionne tous les éléments correspondant à <li> qui sont visibles. |
29 | $("li:hidden") Sélectionne tous les éléments correspondant à <li> qui sont masqués. |
30 | $(":radio") Sélectionne tous les boutons radio du formulaire. |
31 | $(":checked") Sélectionne toutes les cases cochées dans le formulaire. |
32 | $(":input") Sélectionne uniquement les éléments du formulaire (entrée, sélection, zone de texte, bouton). |
33 | $(":text") Sélectionne uniquement les éléments de texte (input [type = text]). |
34 | $("li:eq(2)") Sélectionne le troisième élément <li>. |
35 | $("li:eq(4)") Sélectionne le cinquième élément <li>. |
36 | $("li:lt(2)") Sélectionne tous les éléments correspondant à l'élément <li> avant le troisième; en d'autres termes, les deux premiers éléments <li>. |
37 | $("p:lt(3)") sélectionne tous les éléments correspondant aux éléments <p> avant le quatrième; en d'autres termes les trois premiers éléments <p>. |
38 | $("li:gt(1)") Sélectionne tous les éléments correspondant à <li> après le second. |
39 | $("p:gt(2)") Sélectionne tous les éléments correspondant à <p> après le troisième. |
40 | $("div/p") Sélectionne tous les éléments correspondant à <p> qui sont les enfants d'un élément correspondant à <div>. |
41 | $("div//code") Sélectionne tous les éléments correspondant à <code> qui sont les descendants d'un élément correspondant à <div>. |
42 | $("//p//a") Sélectionne tous les éléments correspondant à <a> qui sont les descendants d'un élément correspondant à <p> |
43 | $("li:first-child") Sélectionne tous les éléments correspondant à <li> qui sont le premier enfant de leur parent. |
44 | $("li:last-child") Sélectionne tous les éléments correspondant à <li> qui sont le dernier enfant de leur parent. |
45 | $(":parent") Sélectionne tous les éléments qui sont le parent d'un autre élément, y compris le texte. |
46 | $("li:contains(second)") Sélectionne tous les éléments correspondant à <li> qui contiennent le texte en second. |
Vous pouvez utiliser tous les sélecteurs ci-dessus avec n'importe quel élément HTML / XML de manière générique. Par exemple si selector$("li:first") fonctionne pour l'élément <li> alors $("p:first") fonctionnerait également pour l'élément <p>.