jQuery - Attributs
Certains des composants les plus basiques que nous pouvons manipuler en ce qui concerne les éléments DOM sont les propriétés et les attributs attribués à ces éléments.
La plupart de ces attributs sont disponibles via JavaScript en tant que propriétés de noeud DOM. Certaines des propriétés les plus courantes sont -
- className
- tagName
- id
- href
- title
- rel
- src
Considérez le balisage HTML suivant pour un élément d'image -
<img id = "imageid" src = "image.gif" alt = "Image" class = "myclass"
title = "This is an image"/>
Dans le balisage de cet élément, le nom de la balise est img et le balisage pour id, src, alt, class et title représente les attributs de l'élément, chacun se composant d'un nom et d'une valeur.
jQuery nous donne les moyens de manipuler facilement les attributs d'un élément et nous donne accès à l'élément afin que nous puissions également modifier ses propriétés.
Obtenir la valeur d'attribut
le attr() peut être utilisée pour récupérer la valeur d'un attribut du premier élément de l'ensemble correspondant ou pour définir des valeurs d'attribut sur tous les éléments correspondants.
Exemple
Voici un exemple simple qui récupère l'attribut title de la balise <em> et définit la valeur <div id = "divid"> avec la même valeur -
<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() {
var title = $("em").attr("title");
$("#divid").text(title);
});
</script>
</head>
<body>
<div>
<em title = "Bold and Brave">This is first paragraph.</em>
<p id = "myid">This is second paragraph.</p>
<div id = "divid"></div>
</div>
</body>
</html>
Cela produira le résultat suivant -
Définir la valeur d'attribut
le attr(name, value) peut être utilisée pour définir l'attribut nommé sur tous les éléments de l'ensemble encapsulé à l'aide de la valeur transmise.
Exemple
Voici un exemple simple qui définit src attribut d'une balise d'image à un emplacement correct -
<html>
<head>
<title>The jQuery Example</title>
<base href="https://www.tutorialspoint.com" />
<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() {
$("#myimg").attr("src", "/jquery/images/jquery.jpg");
});
</script>
</head>
<body>
<div>
<img id = "myimg" src = "/images/jquery.jpg" alt = "Sample image" />
</div>
</body>
</html>
Cela produira le résultat suivant -
Appliquer des styles
le addClass( classes )peut être utilisée pour appliquer des feuilles de style définies sur tous les éléments correspondants. Vous pouvez spécifier plusieurs classes séparées par un espace.
Exemple
Voici un exemple simple qui définit class attribut d'une balise para <p> -
<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() {
$("em").addClass("selected");
$("#myid").addClass("highlight");
});
</script>
<style>
.selected { color:red; }
.highlight { background:yellow; }
</style>
</head>
<body>
<em title = "Bold and Brave">This is first paragraph.</em>
<p id = "myid">This is second paragraph.</p>
</body>
</html>
Cela produira le résultat suivant -
Méthodes d'attribut
Le tableau suivant répertorie quelques méthodes utiles que vous pouvez utiliser pour manipuler les attributs et les propriétés -
N ° Sr. | Méthodes et description |
---|---|
1 | attr (propriétés) Définissez un objet clé / valeur comme propriétés de tous les éléments correspondants. |
2 | attr (clé, fn) Définissez une propriété unique sur une valeur calculée, sur tous les éléments correspondants. |
3 | removeAttr (nom) Supprimez un attribut de chacun des éléments correspondants. |
4 | hasClass (classe) Renvoie true si la classe spécifiée est présente sur au moins l'un des éléments correspondants. |
5 | removeClass (classe) Supprime tout ou la ou les classes spécifiées de l'ensemble des éléments correspondants. |
6 | toggleClass (classe) Ajoute la classe spécifiée si elle n'est pas présente, supprime la classe spécifiée si elle est présente. |
sept | html () Récupère le contenu html (innerHTML) du premier élément correspondant. |
8 | html (val) Définissez le contenu html de chaque élément correspondant. |
9 | texte( ) Obtenez le contenu textuel combiné de tous les éléments correspondants. |
dix | texte (val) Définissez le contenu du texte de tous les éléments correspondants. |
11 | val () Récupère la valeur d'entrée du premier élément correspondant. |
12 | val (val) Définissez l'attribut value de chaque élément correspondant s'il est appelé sur <input> mais s'il est appelé sur <select> avec la valeur <option> passée, l'option passée serait sélectionnée, si elle est appelée sur la case à cocher ou la case radio, alors toutes les cases à cocher et radiobox correspondants seraient cochés. |
Exemples
Semblable à la syntaxe et aux exemples ci-dessus, les exemples suivants vous permettront de comprendre comment utiliser diverses méthodes d'attributs dans différentes situations -
N ° Sr. | Sélecteur et description |
---|---|
1 | $("#myID").attr("custom") Cela renverrait la valeur de l'attribut personnalisé pour le premier élément correspondant à l'ID myID. |
2 | $("img").attr("alt", "Sample Image") Cela définit le alt attribut de toutes les images à une nouvelle valeur "Sample Image". |
3 | $("input").attr({ value: "", title: "Please enter a value" }); Définit la valeur de tous les éléments <input> sur la chaîne vide, ainsi que définit l'exemple jQuery sur la chaîne Veuillez saisir une valeur . |
4 | $("a[href^=https://]").attr("target","_blank") Sélectionne tous les liens avec un attribut href commençant par https: // et définit son attribut cible sur _blank . |
5 | $("a").removeAttr("target") Cela supprimerait l' attribut cible de tous les liens. |
6 | $("form").submit(function() {$(":submit",this).attr("disabled", "disabled");}); Cela modifierait l'attribut désactivé à la valeur «désactivé» en cliquant sur le bouton Soumettre. |
sept | $("p:last").hasClass("selected") Ce retourne true si la dernière balise <p> a sélectionné la classe associée . |
8 | $("p").text() Renvoie une chaîne contenant le contenu textuel combiné de tous les éléments <p> correspondants. |
9 | $("p").text("<i>Hello World</i>") Cela définirait "<I> Hello World </I>" comme contenu textuel des éléments <p> correspondants. |
dix | $("p").html() Cela renvoie le contenu HTML de tous les paragraphes correspondants. |
11 | $("div").html("Hello World") Cela définirait le contenu HTML de tous les <div> correspondants sur Hello World . |
12 | $("input:checkbox:checked").val() Obtenez la première valeur d'une case cochée. |
13 | $("input:radio[name=bar]:checked").val() Obtenez la première valeur d'un ensemble de boutons radio. |
14 | $("button").val("Hello") Définit l'attribut value de chaque élément correspondant <button>. |
15 | $("input").val("on") Cela vérifierait tous les boutons radio ou case à cocher dont la valeur est "on". |
16 | $("select").val("Orange") Cela sélectionnerait l'option Orange dans une liste déroulante avec les options Orange, Mango et Banana. |
17 | $("select").val("Orange", "Mango") Cela sélectionnerait les options Orange et Mango dans une liste déroulante avec les options Orange, Mangue et Banane. |