jQuery - Guide rapide

Qu'est-ce que jQuery?

jQuery est une bibliothèque JavaScript rapide et concise créée par John Resig en 2006 avec une belle devise: Write less, do more. jQuery simplifie la traversée des documents HTML, la gestion des événements, l'animation et les interactions Ajax pour un développement Web rapide. jQuery est une boîte à outils JavaScript conçue pour simplifier diverses tâches en écrivant moins de code. Voici la liste des fonctionnalités principales importantes prises en charge par jQuery -

  • DOM manipulation - Le jQuery a facilité la sélection des éléments DOM, leur négociation et la modification de leur contenu à l'aide d'un moteur de sélection open source inter-navigateurs appelé Sizzle.

  • Event handling - Le jQuery offre un moyen élégant de capturer une grande variété d'événements, comme un utilisateur cliquant sur un lien, sans avoir besoin d'encombrer le code HTML lui-même avec des gestionnaires d'événements.

  • AJAX Support - Le jQuery vous aide beaucoup à développer un site réactif et riche en fonctionnalités en utilisant la technologie AJAX.

  • Animations - Le jQuery est livré avec de nombreux effets d'animation intégrés que vous pouvez utiliser dans vos sites Web.

  • Lightweight - La jQuery est une bibliothèque très légère - environ 19 Ko de taille (réduite et gzippée).

  • Cross Browser Support - Le jQuery prend en charge plusieurs navigateurs et fonctionne bien dans IE 6.0+, FF 2.0+, Safari 3.0+, Chrome et Opera 9.0+

  • Latest Technology - Le jQuery prend en charge les sélecteurs CSS3 et la syntaxe XPath de base.

Comment utiliser jQuery?

Il existe deux façons d'utiliser jQuery.

  • Local Installation - Vous pouvez télécharger la bibliothèque jQuery sur votre machine locale et l'inclure dans votre code HTML.

  • CDN Based Version - Vous pouvez inclure la bibliothèque jQuery dans votre code HTML directement à partir du Content Delivery Network (CDN).

Installation locale

  • Aller à la https://jquery.com/download/ pour télécharger la dernière version disponible.

  • Maintenant mis téléchargé jquery-2.1.3.min.js fichier dans un répertoire de votre site Web, par exemple / jquery.

Exemple

Vous pouvez maintenant inclure la bibliothèque jquery dans votre fichier HTML comme suit -

<html>
   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" src = "/jquery/jquery-2.1.3.min.js">
      </script>
		
      <script type = "text/javascript">
         $(document).ready(function() {
            document.write("Hello, World!");
         });
      </script>
   </head>
	
   <body>
      <h1>Hello</h1>
   </body>
</html>

Cela produira le résultat suivant -

Version basée sur CDN

Vous pouvez inclure la bibliothèque jQuery dans votre code HTML directement à partir du Content Delivery Network (CDN). Google et Microsoft fournissent du contenu pour la dernière version.

Nous utilisons la version Google CDN de la bibliothèque tout au long de ce didacticiel.

Exemple

Maintenant, réécrivons l'exemple ci-dessus en utilisant la bibliothèque jQuery de Google CDN.

<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">
         $(document).ready(function() {
            document.write("Hello, World!");
         });
      </script>
   </head>
	
   <body>
      <h1>Hello</h1>
   </body>
</html>

Cela produira le résultat suivant -

Comment appeler des fonctions de bibliothèque jQuery?

Comme presque tout, nous le faisons lorsque jQuery lit ou manipule le modèle objet de document (DOM), nous devons nous assurer que nous commençons à ajouter des événements, etc. dès que le DOM est prêt.

Si vous voulez qu'un événement fonctionne sur votre page, vous devez l'appeler dans la fonction $ (document) .ready (). Tout ce qu'il contient se chargera dès que le DOM sera chargé et avant que le contenu de la page ne soit chargé.

Pour ce faire, nous enregistrons un événement prêt pour le document comme suit -

$(document).ready(function() {
   // do stuff when DOM is ready
});

Pour appeler une fonction de bibliothèque jQuery, utilisez des balises de script HTML comme indiqué ci-dessous -

<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() { $("div").click(function() {alert("Hello, world!");});
         });
      </script>
   </head>
	
   <body>
      <div id = "mydiv">
         Click on this to see a dialogue box.
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Comment utiliser des scripts personnalisés?

Il est préférable d'écrire notre code personnalisé dans le fichier JavaScript personnalisé: custom.js, comme suit -

/* Filename: custom.js */
$(document).ready(function() { $("div").click(function() {
      alert("Hello, world!");
   });
});

Maintenant, nous pouvons inclure custom.js fichier dans notre fichier HTML comme suit -

<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" src = "/jquery/custom.js">
      </script>
   </head>
	
   <body>
      <div id = "mydiv">
         Click on this to see a dialogue box.
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Utilisation de plusieurs bibliothèques

Vous pouvez utiliser plusieurs bibliothèques toutes ensemble sans entrer en conflit. Par exemple, vous pouvez utiliser les bibliothèques javascript jQuery et MooTool ensemble. Vous pouvez consulter la méthode jQuery noConflict pour plus de détails.

Quelle est la prochaine ?

Ne vous inquiétez pas trop si vous n'avez pas compris les exemples ci-dessus. Vous allez les saisir très bientôt dans les chapitres suivants.

Le chapitre suivant essaiera de couvrir quelques concepts de base qui proviennent de JavaScript conventionnel.

jQuery est un framework construit à l'aide des capacités JavaScript. Ainsi, vous pouvez utiliser toutes les fonctions et autres capacités disponibles dans JavaScript. Ce chapitre explique les concepts les plus basiques mais fréquemment utilisés dans jQuery.

Chaîne

Une chaîne en JavaScript est un objet immuable qui ne contient aucun, un ou plusieurs caractères. Voici les exemples valides d'une chaîne JavaScript -

"This is JavaScript String"
'This is JavaScript String'
'This is "really" a JavaScript String'
"This is 'really' a JavaScript String"

Nombres

Les nombres en JavaScript sont des valeurs IEEE 754 au format 64 bits double précision. Ils sont immuables, tout comme des chaînes. Voici les exemples valides de numéros JavaScript -

5350
120.27
0.26

Booléen

Un booléen en JavaScript peut être soit true ou false. Si un nombre est égal à zéro, la valeur par défaut est false. Si une chaîne vide par défaut est false.

Voici les exemples valides d'un booléen JavaScript -

true      // true
false     // false
0         // false
1         // true
""        // false
"hello"   // true

Objets

JavaScript supporte très bien le concept Object. Vous pouvez créer un objet en utilisant le littéral objet comme suit -

var emp = {
   name: "Zara",
   age: 10
};

Vous pouvez écrire et lire les propriétés d'un objet en utilisant la notation par points comme suit -

// Getting object properties
emp.name  // ==> Zara
emp.age   // ==> 10

// Setting object properties
emp.name = "Daisy"  // <== Daisy
emp.age  =  20      // <== 20

Tableaux

Vous pouvez définir des tableaux en utilisant le littéral de tableau comme suit -

var x = [];
var y = [1, 2, 3, 4, 5];

Un tableau a un length propriété utile pour l'itération -

var x = [1, 2, 3, 4, 5];

for (var i = 0; i < x.length; i++) {
   // Do something with x[i]
}

Les fonctions

Une fonction en JavaScript peut être nommée ou anonyme. Une fonction nommée peut être définie à l'aide du mot-clé de fonction comme suit -

function named(){
   // do some stuff here
}

Une fonction anonyme peut être définie de la même manière qu'une fonction normale mais elle n'aurait pas de nom.

Une fonction anonyme peut être affectée à une variable ou transmise à une méthode comme indiqué ci-dessous.

var handler = function (){
   // do some stuff here
}

JQuery utilise très fréquemment des fonctions anonymes comme suit -

$(document).ready(function(){
   // do some stuff here
});

Arguments

Les arguments de variable JavaScript sont une sorte de tableau qui a la propriété length . L'exemple suivant l'explique très bien -

function func(x){
   console.log(typeof x, arguments.length);
}

func();                //==> "undefined", 0
func(1);               //==> "number", 1
func("1", "2", "3");   //==> "string", 3

L'objet arguments a également une propriété callee , qui fait référence à la fonction dans laquelle vous êtes. Par exemple -

function func() {
   return arguments.callee; 
}

func();                // ==> func

Le contexte

Mot clé JavaScript célèbre thisfait toujours référence au contexte actuel. Dans une fonctionthis le contexte peut changer, selon la façon dont la fonction est appelée -

$(document).ready(function() {
   // this refers to window.document
});

$("div").click(function() {
   // this refers to a div DOM element
});

Vous pouvez spécifier le contexte d'un appel de fonction à l'aide des méthodes intégrées aux fonctions call() et apply() méthodes.

La différence entre eux est la façon dont ils transmettent les arguments. Call transmet tous les arguments en tant qu'arguments à la fonction, tandis que apply accepte un tableau comme arguments.

function scope() {
   console.log(this, arguments.length);
}

scope() // window, 0
scope.call("foobar", [1,2]);  //==> "foobar", 1
scope.apply("foobar", [1,2]); //==> "foobar", 2

Portée

La portée d'une variable est la région de votre programme dans laquelle elle est définie. La variable JavaScript n'aura que deux portées.

  • Global Variables - Une variable globale a une portée globale, ce qui signifie qu'elle est définie partout dans votre code JavaScript.

  • Local Variables- Une variable locale ne sera visible que dans une fonction où elle est définie. Les paramètres de fonction sont toujours locaux à cette fonction.

Dans le corps d'une fonction, une variable locale est prioritaire sur une variable globale du même nom -

var myVar = "global";     // ==> Declare a global variable

function ( ) {
   var myVar = "local";   // ==> Declare a local variable
   document.write(myVar); // ==> local
}

Rappeler

Un rappel est une simple fonction JavaScript transmise à une méthode en tant qu'argument ou option. Certains rappels ne sont que des événements, appelés pour donner à l'utilisateur une chance de réagir lorsqu'un certain état est déclenché.

Le système d'événements de jQuery utilise de tels rappels partout par exemple -

$("body").click(function(event) {
   console.log("clicked: " + event.target);
});

La plupart des rappels fournissent des arguments et un contexte. Dans l'exemple du gestionnaire d'événements, le rappel est appelé avec un argument, un Event.

Certains rappels sont nécessaires pour renvoyer quelque chose, d'autres rendent cette valeur de retour facultative. Pour empêcher une soumission de formulaire, un gestionnaire d'événements d'envoi peut renvoyer false comme suit -

$("#myform").submit(function() {
   return false;
});

Fermetures

Les fermetures sont créées chaque fois qu'une variable définie en dehors de la portée actuelle est accessible depuis une certaine portée interne.

L'exemple suivant montre comment la variable counter est visible dans les fonctions de création, d'incrémentation et d'impression, mais pas en dehors d'elles -

function create() {
   var counter = 0;
	
   return {
      increment: function() {
         counter++;
      },
	   print: function() {
         console.log(counter);
      }
   }
}

var c = create();
c.increment();
c.print();     // ==> 1

Ce modèle vous permet de créer des objets avec des méthodes qui opèrent sur des données qui ne sont pas visibles du monde extérieur. Il faut noter quedata hiding est la base même de la programmation orientée objet.

Modèle de proxy

Un proxy est un objet qui peut être utilisé pour contrôler l'accès à un autre objet. Il implémente la même interface que cet autre objet et lui transmet toutes les invocations de méthode. Cet autre objet est souvent appelé le vrai sujet.

Un proxy peut être instancié à la place de ce sujet réel et lui permettre d'être accessible à distance. Nous pouvons enregistrer la méthode setArray de jQuery dans une fermeture et l'écraser comme suit -

(function() {
   // log all calls to setArray
   var proxied = jQuery.fn.setArray;

   jQuery.fn.setArray = function() {
      console.log(this, arguments);
      return proxied.apply(this, arguments);
   };
	
})();

Ce qui précède enveloppe son code dans une fonction pour masquer la variable mandatée . Le proxy enregistre ensuite tous les appels à la méthode et délègue l'appel à la méthode d'origine. L' utilisation de apply (this, arguments) garantit que l'appelant ne pourra pas remarquer la différence entre la méthode d'origine et la méthode mandatée.

Fonctions intégrées

JavaScript est livré avec un ensemble utile de fonctions intégrées. Ces méthodes peuvent être utilisées pour manipuler des chaînes, des nombres et des dates.

Voici les fonctions JavaScript importantes -

Sr.No. Méthode et description
1

charAt()

Renvoie le caractère à l'index spécifié.

2

concat()

Combine le texte de deux chaînes et renvoie une nouvelle chaîne.

3

forEach()

Appelle une fonction pour chaque élément du tableau.

4

indexOf()

Renvoie l'index dans l'objet String appelant de la première occurrence de la valeur spécifiée, ou -1 s'il est introuvable.

5

length()

Renvoie la longueur de la chaîne.

6

pop()

Supprime le dernier élément d'un tableau et renvoie cet élément.

sept

push()

Ajoute un ou plusieurs éléments à la fin d'un tableau et renvoie la nouvelle longueur du tableau.

8

reverse()

Inverse l'ordre des éléments d'un tableau - le premier devient le dernier et le dernier devient le premier.

9

sort()

Trie les éléments d'un tableau.

dix

substr()

Renvoie les caractères d'une chaîne commençant à l'emplacement spécifié jusqu'au nombre de caractères spécifié.

11

toLowerCase()

Renvoie la valeur de la chaîne appelante convertie en minuscules.

12

toString()

Renvoie la représentation sous forme de chaîne de la valeur du nombre.

13

toUpperCase()

Renvoie la valeur de la chaîne appelante convertie en majuscules.

Le modèle objet de document

Le modèle d'objet de document est une structure arborescente de divers éléments HTML comme suit -

<html>
   <head>
      <title>The jQuery Example</title>
   </head>
	
   <body>
      <div>
         <p>This is a paragraph.</p>
         <p>This is second paragraph.</p>
         <p>This is third paragraph.</p>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Voici les points importants concernant l'arborescence ci-dessus -

  • Le <html> est l'ancêtre de tous les autres éléments; en d'autres termes, tous les autres éléments sont des descendants de <html>.

  • Les éléments <head> et <body> ne sont pas seulement des descendants, mais aussi des enfants de <html>.

  • De même, en plus d'être l'ancêtre de <head> et <body>, <html> est également leur parent.

  • Les éléments <p> sont les enfants (et descendants) de <div>, les descendants de <body> et <html>, et les frères et sœurs des autres éléments <p>.

Tout en apprenant les concepts de jQuery, il sera utile d'avoir une compréhension du DOM.Si vous n'êtes pas au courant du DOM, je vous suggère de suivre notre tutoriel simple sur le didacticiel DOM .

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é -

Sr.No. 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.

Sr.No. 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 -

Sr.No. 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>.

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 nœud 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 -

Application de 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 -

Sr.No. 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 ()

Obtenez 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 -

Sr.No. 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 vrai 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 toutes les cases de radio ou de 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.

jQuery est un outil très puissant qui fournit une variété de méthodes de traversée DOM pour nous aider à sélectionner des éléments dans un document de manière aléatoire ainsi que par méthode séquentielle. La plupart des méthodes de traversée DOM ne modifient pas l'objet jQuery et sont utilisées pour filtrer les éléments d'un document en fonction de conditions données.

Rechercher des éléments par index

Considérez un document simple avec le contenu HTML suivant -

<html>
   <head>
      <title>The JQuery Example</title>
   </head>
	
   <body>
      <div>
         <ul>
            <li>list item 1</li>
            <li>list item 2</li>
            <li>list item 3</li>
            <li>list item 4</li>
            <li>list item 5</li>
            <li>list item 6</li>
         </ul>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

  • Au-dessus de chaque liste a son propre index, et peut être localisé directement en utilisant eq(index) méthode comme ci-dessous exemple.

  • Chaque élément enfant commence son index à partir de zéro, ainsi, l' élément de liste 2 serait accessible en utilisant$("li").eq(1) etc.

Exemple

Voici un exemple simple qui ajoute la couleur au deuxième élément de la liste.

<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() {
            $("li").eq(2).addClass("selected");
         });
      </script>
		
      <style>
         .selected { color:red; }
      </style>
   </head>
	
   <body>
      <div>
         <ul>
            <li>list item 1</li>
            <li>list item 2</li>
            <li>list item 3</li>
            <li>list item 4</li>
            <li>list item 5</li>
            <li>list item 6</li>
         </ul>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Filtrer les éléments

le filter( selector )peut être utilisée pour filtrer tous les éléments de l'ensemble des éléments correspondants qui ne correspondent pas au (x) sélecteur (s) spécifié (s). Le sélecteur peut être écrit en utilisant n'importe quelle syntaxe de sélecteur.

Exemple

Voici un exemple simple qui applique la couleur aux listes associées à la classe moyenne -

<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() {
            $("li").filter(".middle").addClass("selected");
         });
      </script>
		
      <style>
         .selected { color:red; }
      </style>
   </head>
	
   <body>
      <div>
         <ul>
            <li class = "top">list item 1</li>
            <li class = "top">list item 2</li>
            <li class = "middle">list item 3</li>
            <li class = "middle">list item 4</li>
            <li class = "bottom">list item 5</li>
            <li class = "bottom">list item 6</li>
         </ul>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Localisation des éléments descendants

le find( selector )peut être utilisée pour localiser tous les éléments descendants d'un type particulier d'éléments. Le sélecteur peut être écrit en utilisant n'importe quelle syntaxe de sélecteur.

Exemple

Voici un exemple qui sélectionne tous les éléments <span> disponibles dans différents éléments <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() {
            $("p").find("span").addClass("selected");
         });
      </script>
		
      <style>
         .selected { color:red; }
      </style>
   </head>
	
   <body>
      <p>This is 1st paragraph and <span>THIS IS RED</span></p>
      <p>This is 2nd paragraph and <span>THIS IS ALSO RED</span></p>
   </body>
</html>

Cela produira le résultat suivant -

Méthodes de filtrage DOM JQuery

Le tableau suivant répertorie les méthodes utiles que vous pouvez utiliser pour filtrer divers éléments d'une liste d'éléments DOM -

Sr.No. Méthode et description
1 eq (index)

Réduisez l'ensemble des éléments correspondants à un seul élément.

2 filtre (sélecteur)

Supprime tous les éléments de l'ensemble des éléments correspondants qui ne correspondent pas au (x) sélecteur (s) spécifié (s).

3 filtre (fn)

Supprime tous les éléments de l'ensemble des éléments correspondants qui ne correspondent pas à la fonction spécifiée.

4 is (sélecteur)

Vérifie la sélection actuelle par rapport à une expression et renvoie true, si au moins un élément de la sélection correspond au sélecteur donné.

5 map (rappel)

Traduisez un ensemble d'éléments dans l'objet jQuery en un autre ensemble de valeurs dans un tableau jQuery (qui peut ou non contenir des éléments).

6 not (sélecteur)

Supprime les éléments correspondant au sélecteur spécifié de l'ensemble des éléments correspondants.

sept tranche (début, [fin])

Sélectionne un sous-ensemble des éléments correspondants.

Méthodes de parcours JQuery DOM

Le tableau suivant répertorie d'autres méthodes utiles que vous pouvez utiliser pour localiser divers éléments dans un DOM -

Sr.No. Méthodes et description
1 ajouter (sélecteur)

Ajoute d'autres éléments, correspondant au sélecteur donné, à l'ensemble des éléments correspondants.

2 etSoi ()

Ajoutez la sélection précédente à la sélection actuelle.

3 enfants ([sélecteur])

Obtenez un ensemble d'éléments contenant tous les enfants immédiats uniques de chacun des ensembles d'éléments correspondants.

4 le plus proche (sélecteur)

Obtenez un ensemble d'éléments contenant l'élément parent le plus proche qui correspond au sélecteur spécifié, l'élément de départ inclus.

5 Contenu( )

Recherchez tous les nœuds enfants dans les éléments correspondants (y compris les nœuds de texte), ou dans le document de contenu, si l'élément est une iframe.

6 fin( )

Rétablit l'opération «destructrice» la plus récente, en changeant l'ensemble des éléments correspondants à son état précédent.

sept find (sélecteur)

Recherche les éléments descendants qui correspondent aux sélecteurs spécifiés.

8 suivant ([sélecteur])

Obtenez un ensemble d'éléments contenant les frères et sœurs suivants uniques de chacun des ensembles d'éléments donnés.

9 nextAll ([sélecteur])

Trouvez tous les éléments frères après l'élément actuel.

dix offsetParent ()

Renvoie une collection jQuery avec le parent positionné du premier élément correspondant.

11 parent ([sélecteur])

Obtenez le parent direct d'un élément. S'il est appelé sur un ensemble d'éléments, parent renvoie un ensemble de leurs éléments parents directs uniques.

12 parents ([sélecteur])

Obtenez un ensemble d'éléments contenant les ancêtres uniques de l'ensemble d'éléments correspondant (à l'exception de l'élément racine).

13 prev ([sélecteur])

Obtenez un ensemble d'éléments contenant les frères et sœurs précédents uniques de chacun des ensembles d'éléments correspondants.

14 prevAll ([sélecteur])

Trouvez tous les éléments frères devant l'élément actuel.

15 frères et sœurs ([sélecteur])

Obtenez un ensemble d'éléments contenant tous les frères et sœurs uniques de chacun des ensembles d'éléments correspondants.

La bibliothèque jQuery prend en charge presque tous les sélecteurs inclus dans les spécifications de feuille de style en cascade (CSS) 1 à 3, comme indiqué sur le site du World Wide Web Consortium.

À l'aide de la bibliothèque JQuery, les développeurs peuvent améliorer leurs sites Web sans se soucier des navigateurs et de leurs versions tant que les navigateurs ont activé JavaScript.

La plupart des méthodes CSS JQuery ne modifient pas le contenu de l'objet jQuery et sont utilisées pour appliquer des propriétés CSS sur les éléments DOM.

Appliquer les propriétés CSS

C'est très simple d'appliquer n'importe quelle propriété CSS à l'aide de la méthode JQuery css( PropertyName, PropertyValue ).

Voici la syntaxe de la méthode -

selector.css( PropertyName, PropertyValue );

Ici, vous pouvez passer PropertyName en tant que chaîne javascript et en fonction de sa valeur, PropertyValue peut être une chaîne ou un entier.

Exemple

Voici un exemple qui ajoute une couleur de police au deuxième élément de la liste.

<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() {
            $("li").eq(2).css("color", "red");
         });
      </script>
   </head>
	
   <body>
      <div>
         <ul>
            <li>list item 1</li>
            <li>list item 2</li>
            <li>list item 3</li>
            <li>list item 4</li>
            <li>list item 5</li>
            <li>list item 6</li>
         </ul>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Appliquer plusieurs propriétés CSS

Vous pouvez appliquer plusieurs propriétés CSS à l'aide d'une seule méthode JQuery CSS( {key1:val1, key2:val2....). Vous pouvez appliquer autant de propriétés que vous le souhaitez en un seul appel.

Voici la syntaxe de la méthode -

selector.css( {key1:val1, key2:val2....keyN:valN})

Ici, vous pouvez passer key comme propriété et val comme valeur comme décrit ci-dessus.

Exemple

Voici un exemple qui ajoute une couleur de police ainsi qu'une couleur d'arrière-plan au deuxième élément de la liste.

<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() {
            $("li").eq(2).css({"color":"red", "background-color":"green"});
         });
      </script>
   </head>
	
   <body>
      <div>
         <ul>
            <li>list item 1</li>
            <li>list item 2</li>
            <li>list item 3</li>
            <li>list item 4</li>
            <li>list item 5</li>
            <li>list item 6</li>
         </ul>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Réglage de la largeur et de la hauteur de l'élément

le width( val ) et height( val ) peut être utilisée pour définir respectivement la largeur et la hauteur de tout élément.

Exemple

Voici un exemple simple qui définit la largeur du premier élément de division où, comme le reste des éléments, la largeur est définie par la feuille de style

<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() {
            $("div:first").width(100); $("div:first").css("background-color", "blue");
         });
      </script>
		
      <style>
         div { 
            width:70px; height:50px; float:left; 
            margin:5px; background:red; cursor:pointer; 
         }
      </style>
   </head>
	
   <body>
      <div></div>
      <div>d</div>
      <div>d</div>
      <div>d</div>
      <div>d</div>
   </body>
</html>

Cela produira le résultat suivant -

Méthodes CSS JQuery

Le tableau suivant répertorie toutes les méthodes que vous pouvez utiliser pour jouer avec les propriétés CSS -

Sr.No. Méthode et description
1 css (nom)

Renvoie une propriété de style sur le premier élément correspondant.

2 css (nom, valeur)

Définissez une propriété de style unique sur une valeur sur tous les éléments correspondants.

3 css (propriétés)

Définissez un objet clé / valeur comme propriétés de style pour tous les éléments correspondants.

4 hauteur (val)

Définissez la hauteur CSS de chaque élément correspondant.

5 la taille( )

Obtenez le pixel, la hauteur actuelle calculée du premier élément correspondant.

6 innerHeight ()

Obtient la hauteur intérieure (exclut la bordure et inclut le remplissage) pour le premier élément correspondant.

sept innerWidth ()

Obtient la largeur intérieure (exclut la bordure et inclut le remplissage) pour le premier élément correspondant.

8 décalage( )

Obtenez le décalage actuel du premier élément correspondant, en pixels, par rapport au document.

9 offsetParent ()

Renvoie une collection jQuery avec le parent positionné du premier élément correspondant.

dix externalHeight ([margin])

Obtient la hauteur extérieure (inclut la bordure et le remplissage par défaut) pour le premier élément correspondant.

11 externalWidth ([margin])

Obtenez la largeur extérieure (inclut la bordure et le remplissage par défaut) pour le premier élément correspondant.

12 position( )

Obtient la position supérieure et gauche d'un élément par rapport à son parent offset.

13 scrollLeft (val)

Lorsqu'une valeur est transmise, le décalage de défilement vers la gauche est défini sur cette valeur sur tous les éléments correspondants.

14 scrollLeft ()

Obtient le décalage gauche de défilement du premier élément correspondant.

15 scrollTop (val)

Lorsqu'une valeur est transmise, le décalage supérieur du défilement est défini sur cette valeur sur tous les éléments correspondants.

16 scrollTop ()

Obtient le décalage supérieur de défilement du premier élément correspondant.

17 largeur (val)

Définissez la largeur CSS de chaque élément correspondant.

18 largeur( )

Récupère la largeur actuelle, en pixels, calculée du premier élément correspondant.

JQuery fournit des méthodes pour manipuler le DOM de manière efficace. Vous n'avez pas besoin d'écrire du gros code pour modifier la valeur de l'attribut d'un élément ou pour extraire du code HTML d'un paragraphe ou d'une division.

JQuery fournit des méthodes telles que .attr (), .html () et .val () qui agissent comme des getters, récupérant des informations à partir d'éléments DOM pour une utilisation ultérieure.

Manipulation de contenu

le html( ) La méthode obtient le contenu html (innerHTML) du premier élément correspondant.

Voici la syntaxe de la méthode -

selector.html( )

Exemple

Voici un exemple qui utilise les méthodes .html () et .text (val). Ici .html () récupère le contenu HTML de l'objet, puis la méthode .text (val) définit la valeur de l'objet en utilisant le paramètre passé -

<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() { $("div").click(function () {
               var content = $(this).html(); $("#result").text( content );
            });
         });
      </script>
		
      <style>
         #division{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on the square below:</p>
      <span id = "result"> </span>
		
      <div id = "division" style = "background-color:blue;">
         This is Blue Square!!
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Remplacement de l'élément DOM

Vous pouvez remplacer un élément DOM complet par les éléments HTML ou DOM spécifiés. lereplaceWith( content ) Cette méthode sert très bien cet objectif.

Voici la syntaxe de la méthode -

selector.replaceWith( content )

Ici, le contenu est ce que vous voulez avoir à la place de l'élément d'origine. Cela peut être du HTML ou du texte simple.

Exemple

Voici un exemple qui remplacerait l'élément de division par "<h1> JQuery is Great </h1>" -

<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() { $("div").click(function () {
               $(this).replaceWith("<h1>JQuery is Great</h1>");
            });
         });
      </script>
		
      <style>
         #division{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on the square below:</p>
      <span id = "result"> </span>
		
      <div id = "division" style = "background-color:blue;">
         This is Blue Square!!
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Suppression d'éléments DOM

Il se peut que vous souhaitiez supprimer un ou plusieurs éléments DOM du document. JQuery fournit deux méthodes pour gérer la situation.

le empty( ) méthode supprime tous les nœuds enfants de l'ensemble des éléments correspondants où comme méthode remove( expr ) La méthode supprime tous les éléments correspondants du DOM.

Voici la syntaxe de la méthode -

selector.remove( [ expr ])

or 

selector.empty( )

Vous pouvez passer le paramètre optionnel expr pour filtrer l'ensemble des éléments à supprimer.

Exemple

Voici un exemple où les éléments sont supprimés dès qu'ils sont cliqués -

<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() {
            $("div").click(function () { $(this).remove( );
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below:</p>
      <span id = "result"> </span>
		
      <div class = "div" style = "background-color:blue;"></div>
      <div class = "div" style = "background-color:green;"></div>
      <div class = "div" style = "background-color:red;"></div>
   </body>
</html>

Cela produira le résultat suivant -

Insertion d'éléments DOM

Il se peut que vous souhaitiez insérer un ou plusieurs éléments DOM dans votre document existant. JQuery fournit diverses méthodes pour insérer des éléments à divers emplacements.

le after( content ) méthode insérer du contenu après chacun des éléments correspondants où comme méthode before( content ) La méthode insère le contenu avant chacun des éléments correspondants.

Voici la syntaxe de la méthode -

selector.after( content )

or

selector.before( content )

Voici le contenu que vous souhaitez insérer. Cela peut être du HTML ou du texte simple.

Exemple

Voici un exemple où des éléments <div> sont insérés juste avant l'élément cliqué -

<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() { $("div").click(function () {
               $(this).before('<div class="div"></div>' );
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below:</p>
      <span id = "result"> </span>
		
      <div class = "div" style = "background-color:blue;"></div>
      <div class = "div" style = "background-color:green;"></div>
      <div class = "div" style = "background-color:red;"></div>
   </body>
</html>

Cela produira le résultat suivant -

Méthodes de manipulation DOM

Le tableau suivant répertorie toutes les méthodes que vous pouvez utiliser pour manipuler les éléments DOM -

Sr.No. Méthode et description
1 après (contenu)

Insérez du contenu après chacun des éléments correspondants.

2 ajouter (contenu)

Ajoutez du contenu à l'intérieur de chaque élément correspondant.

3 appendTo (sélecteur)

Ajoutez tous les éléments correspondants à un autre ensemble d'éléments spécifié.

4 avant (contenu)

Insérez le contenu avant chacun des éléments correspondants.

5 clone (booléen)

Clonez les éléments DOM correspondants, et tous leurs gestionnaires d'événements, et sélectionnez les clones.

6 cloner ()

Clonez les éléments DOM correspondants et sélectionnez les clones.

sept vide( )

Supprimez tous les nœuds enfants de l'ensemble des éléments correspondants.

8 html (val)

Définissez le contenu html de chaque élément correspondant.

9 html ()

Obtenez le contenu html (innerHTML) du premier élément correspondant.

dix insertAfter (sélecteur)

Insérez tous les éléments correspondants après un autre ensemble d'éléments spécifié.

11 insertBefore (sélecteur)

Insérez tous les éléments correspondants avant un autre ensemble d'éléments spécifié.

12 préfixer (contenu)

Ajoutez du contenu à l'intérieur de chaque élément correspondant.

13 prependTo (sélecteur)

Ajoutez tous les éléments correspondants à un autre ensemble d'éléments spécifié.

14 supprimer (expr)

Supprime tous les éléments correspondants du DOM.

15 replaceAll (sélecteur)

Remplace les éléments mis en correspondance par le sélecteur spécifié par les éléments correspondants.

16 replaceWith (contenu)

Remplace tous les éléments correspondants par les éléments HTML ou DOM spécifiés.

17 texte (val)

Définissez le contenu du texte de tous les éléments correspondants.

18 texte( )

Obtenez le contenu textuel combiné de tous les éléments correspondants.

19 wrap (elem)

Enveloppez chaque élément correspondant avec l'élément spécifié.

20 wrap (html)

Enveloppez chaque élément correspondant avec le contenu HTML spécifié.

21 wrapAll (elem)

Enveloppez tous les éléments de l'ensemble correspondant dans un seul élément wrapper.

22 wrapAll (html)

Enveloppez tous les éléments de l'ensemble correspondant dans un seul élément wrapper.

23 wrapInner (elem)

Enveloppez le contenu enfant interne de chaque élément correspondant (y compris les nœuds de texte) avec un élément DOM.

24 wrapInner (html)

Enveloppez le contenu enfant interne de chaque élément correspondant (y compris les nœuds de texte) avec une structure HTML.

Nous avons la possibilité de créer des pages Web dynamiques en utilisant des événements. Les événements sont des actions qui peuvent être détectées par votre application Web.

Voici les exemples d'événements -

  • Un clic de souris
  • Une page Web en cours de chargement
  • Passer la souris sur un élément
  • Soumettre un formulaire HTML
  • Une frappe sur votre clavier, etc.

Lorsque ces événements sont déclenchés, vous pouvez ensuite utiliser une fonction personnalisée pour faire à peu près tout ce que vous voulez avec l'événement. Ces fonctions personnalisées appellent des gestionnaires d'événements.

Gestionnaires d'événements de liaison

En utilisant le modèle d'événement jQuery, nous pouvons établir des gestionnaires d'événements sur les éléments DOM avec le bind() méthode comme suit -

<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() {
            $('div').bind('click', function( event ){
               alert('Hi there!');
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

Ce code provoquera la réponse de l'élément de division à l'événement de clic; lorsqu'un utilisateur clique à l'intérieur de cette division par la suite, l'alerte sera affichée.

Cela produira le résultat suivant -

La syntaxe complète de la commande bind () est la suivante -

selector.bind( eventType[, eventData], handler)

Voici la description des paramètres -

  • eventType- Une chaîne contenant un type d'événement JavaScript, tel que cliquer ou soumettre. Reportez-vous à la section suivante pour une liste complète des types d'événements.

  • eventData - Ce paramètre facultatif est une carte de données qui sera transmise au gestionnaire d'événements.

  • handler - Une fonction à exécuter chaque fois que l'événement est déclenché.

Suppression des gestionnaires d'événements

En règle générale, une fois qu'un gestionnaire d'événements est établi, il reste en vigueur pour le reste de la vie de la page. Il peut être nécessaire de supprimer le gestionnaire d'événements.

jQuery fournit le unbind()commande pour supprimer un gestionnaire d'événements en cours de sortie. La syntaxe de unbind () est la suivante -

selector.unbind(eventType, handler)

or 

selector.unbind(eventType)

Voici la description des paramètres -

  • eventType- Une chaîne contenant un type d'événement JavaScript, tel que cliquer ou soumettre. Reportez-vous à la section suivante pour une liste complète des types d'événements.

  • handler - S'il est fourni, identifie l'auditeur spécifique à supprimer.

Types d'événements

Sr.No. Type d'événement et description
1

blur

Se produit lorsque l'élément perd le focus.

2

change

Se produit lorsque l'élément change.

3

click

Se produit lorsqu'un clic de souris.

4

dblclick

Se produit lorsqu'un double-clic de souris.

5

error

Se produit lorsqu'il y a une erreur de chargement ou de déchargement, etc.

6

focus

Se produit lorsque l'élément obtient le focus.

sept

keydown

Se produit lorsque la touche est enfoncée.

8

keypress

Se produit lorsque la touche est enfoncée et relâchée.

9

keyup

Se produit lorsque la clé est relâchée.

dix

load

Se produit lorsque le document est chargé.

11

mousedown

Se produit lorsque le bouton de la souris est enfoncé.

12

mouseenter

Se produit lorsque la souris entre dans une région d'élément.

13

mouseleave

Se produit lorsque la souris quitte une région d'élément.

14

mousemove

Se produit lorsque le pointeur de la souris se déplace.

15

mouseout

Se produit lorsque le pointeur de la souris sort d'un élément.

16

mouseover

Se produit lorsque le pointeur de la souris se déplace sur un élément.

17

mouseup

Se produit lorsque le bouton de la souris est relâché.

18

resize

Se produit lorsque la fenêtre est redimensionnée.

19

scroll

Se produit lorsque la fenêtre défile.

20

select

Se produit lorsqu'un texte est sélectionné.

21

submit

Se produit lorsque le formulaire est soumis.

22

unload

Se produit lorsque les documents sont déchargés.

L'objet événement

La fonction de rappel prend un seul paramètre; lorsque le gestionnaire est appelé, l'objet événement JavaScript lui sera transmis.

L'objet événement est souvent inutile et le paramètre est omis, car un contexte suffisant est généralement disponible lorsque le gestionnaire est tenu de savoir exactement ce qui doit être fait lorsque le gestionnaire est déclenché, mais il y a certains attributs auxquels vous devez accéder.

Les attributs de l'événement

Sr.No. Propriété et description
1

altKey

Défini sur true si la touche Alt a été enfoncée lors du déclenchement de l'événement, false dans le cas contraire. La touche Alt est intitulée Option sur la plupart des claviers Mac.

2

ctrlKey

Défini sur true si la touche Ctrl a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire.

3

data

La valeur, le cas échéant, transmise comme deuxième paramètre à la commande bind () lors de l'établissement du gestionnaire.

4

keyCode

Pour les événements keyup et keydown, cela renvoie la touche qui a été enfoncée.

5

metaKey

Défini sur true si la touche Meta a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire. La touche Meta est la touche Ctrl sur les PC et la touche Commande sur les Mac.

6

pageX

Pour les événements de souris, spécifie la coordonnée horizontale de l'événement par rapport à l'origine de la page.

sept

pageY

Pour les événements de souris, spécifie la coordonnée verticale de l'événement par rapport à l'origine de la page.

8

relatedTarget

Pour certains événements de souris, identifie l'élément que le curseur a laissé ou entré lorsque l'événement a été déclenché.

9

screenX

Pour les événements de souris, spécifie la coordonnée horizontale de l'événement par rapport à l'origine de l'écran.

dix

screenY

Pour les événements de souris, spécifie la coordonnée verticale de l'événement par rapport à l'origine de l'écran.

11

shiftKey

Défini sur true si la touche Shift a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire.

12

target

Identifie l'élément pour lequel l'événement a été déclenché.

13

timeStamp

L'horodatage (en millisecondes) de la création de l'événement.

14

type

Pour tous les événements, spécifie le type d'événement qui a été déclenché (par exemple, un clic).

15

which

Pour les événements de clavier, spécifie le code numérique de la touche qui a provoqué l'événement et pour les événements de souris, spécifie le bouton qui a été enfoncé (1 pour la gauche, 2 pour le milieu, 3 pour la droite).

<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() {
            $('div').bind('click', function( event ){
               alert('Event type is ' + event.type);
               alert('pageX : ' + event.pageX);
               alert('pageY : ' + event.pageY);
               alert('Target : ' + event.target.innerHTML);
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

Cela produira le résultat suivant -

Les méthodes d'événement

Il existe une liste de méthodes qui peuvent être appelées sur un objet événement -

Sr.No. Méthode et description
1 preventDefault ()

Empêche le navigateur d'exécuter l'action par défaut.

2 isDefaultPrevented ()

Renvoie si event.preventDefault () a été appelé sur cet objet événement.

3 stopPropagation ()

Arrête la propagation d'un événement vers les éléments parents, empêchant ainsi les gestionnaires parents d'être notifiés de l'événement.

4 isPropagationStopped ()

Renvoie si event.stopPropagation () a été appelée sur cet objet événement.

5 stopImmediatePropagation ()

Arrête l'exécution du reste des gestionnaires.

6 isImmediatePropagationStopped ()

Renvoie si event.stopImmediatePropagation () a jamais été appelé sur cet objet événement.

Méthodes de manipulation d'événements

Le tableau suivant répertorie les méthodes importantes liées aux événements -

Sr.No. Méthode et description
1 bind (type, [données], fn)

Lie un gestionnaire à un ou plusieurs événements (comme un clic) pour chaque élément correspondant. Peut également lier des événements personnalisés.

2 off (events [, selector] [, handler (eventObject)])

Cela fait le contraire du live, cela supprime un événement live lié.

3 survoler (au-dessus, en dehors)

Simule le survol, par exemple en déplaçant la souris sur et en dehors d'un objet.

4 on (événements [, sélecteur] [, données], gestionnaire)

Lie un gestionnaire à un événement (comme click) pour tous les éléments correspondants actuels et futurs. Peut également lier des événements personnalisés.

5 un (type, [données], fn)

Lie un gestionnaire à un ou plusieurs événements à exécuter une fois pour chaque élément correspondant.

6 prêt (fn)

Lie une fonction à exécuter chaque fois que le DOM est prêt à être parcouru et manipulé.

sept déclencheur (événement, [données])

Déclenchez un événement sur chaque élément correspondant.

8 triggerHandler (événement, [données])

Déclenche tous les gestionnaires d'événements liés sur un élément.

9 unbind ([type], [fn])

Cela fait le contraire de bind, il supprime les événements liés de chacun des éléments correspondants.

Méthodes d'assistance d'événement

jQuery fournit également un ensemble de fonctions d'assistance d'événement qui peuvent être utilisées soit pour déclencher un événement afin de lier tous les types d'événements mentionnés ci-dessus.

Méthodes de déclenchement

Voici un exemple qui déclencherait l'événement de flou sur tous les paragraphes -

$("p").blur();

Méthodes de liaison

Voici un exemple qui lierait un click événement sur tous les <div> -

$("div").click( function () { 
   // do something here
});
Sr.No. Méthode et description
1

blur( )

Déclenche l'événement de flou de chaque élément correspondant.

2

blur( fn )

Liez une fonction à l'événement de flou de chaque élément correspondant.

3

change( )

Déclenche l'événement de modification de chaque élément correspondant.

4

change( fn )

Lie une fonction à l'événement de modification de chaque élément correspondant.

5

click( )

Déclenche l'événement de clic de chaque élément correspondant.

6

click( fn )

Lie une fonction à l'événement click de chaque élément correspondant.

sept

dblclick( )

Déclenche l'événement dblclick de chaque élément correspondant.

8

dblclick( fn )

Lie une fonction à l'événement dblclick de chaque élément correspondant.

9

error( )

Déclenche l'événement d'erreur de chaque élément correspondant.

dix

error( fn )

Lie une fonction à l'événement d'erreur de chaque élément correspondant.

11

focus( )

Déclenche l'événement de focus de chaque élément correspondant.

12

focus( fn )

Lie une fonction à l'événement de focus de chaque élément correspondant.

13

keydown( )

Déclenche l'événement keydown de chaque élément correspondant.

14

keydown( fn )

Liez une fonction à l'événement keydown de chaque élément correspondant.

15

keypress( )

Déclenche l'événement keypress de chaque élément correspondant.

16

keypress( fn )

Lie une fonction à l'événement keypress de chaque élément correspondant.

17

keyup( )

Déclenche l'événement keyup de chaque élément correspondant.

18

keyup( fn )

Liez une fonction à l'événement keyup de chaque élément correspondant.

19

load( fn )

Lie une fonction à l'événement load de chaque élément correspondant.

20

mousedown( fn )

Lie une fonction à l'événement mousedown de chaque élément correspondant.

21

mouseenter( fn )

Liez une fonction à l'événement mouseenter de chaque élément correspondant.

22

mouseleave( fn )

Liez une fonction à l'événement mouseleave de chaque élément correspondant.

23

mousemove( fn )

Liez une fonction à l'événement mousemove de chaque élément correspondant.

24

mouseout( fn )

Liez une fonction à l'événement mouseout de chaque élément correspondant.

25

mouseover( fn )

Liez une fonction à l'événement mouseover de chaque élément correspondant.

26

mouseup( fn )

Liez une fonction à l'événement mouseup de chaque élément correspondant.

27

resize( fn )

Liez une fonction à l'événement resize de chaque élément correspondant.

28

scroll( fn )

Liez une fonction à l'événement de défilement de chaque élément correspondant.

29

select( )

Déclenchez l'événement de sélection de chaque élément correspondant.

30

select( fn )

Liez une fonction à l'événement select de chaque élément correspondant.

31

submit( )

Déclenchez l'événement de soumission de chaque élément correspondant.

32

submit( fn )

Liez une fonction à l'événement submit de chaque élément correspondant.

33

unload( fn )

Lie une fonction à l'événement de déchargement de chaque élément correspondant.

AJAX est un acronyme pour JavaScript et XML asynchrones et cette technologie nous aide à charger des données à partir du serveur sans actualisation de la page du navigateur.

Si vous êtes nouveau avec AJAX, je vous recommande de parcourir notre Tutoriel Ajax avant de continuer.

JQuery est un excellent outil qui fournit un riche ensemble de méthodes AJAX pour développer une application Web de nouvelle génération.

Chargement de données simples

Il est très facile de charger des données statiques ou dynamiques à l'aide de JQuery AJAX. JQuery fournitload() méthode pour faire le travail -

Syntaxe

Voici la syntaxe simple pour load() méthode -

[selector].load( URL, [data], [callback] );

Voici la description de tous les paramètres -

  • URL- L'URL de la ressource côté serveur à laquelle la demande est envoyée. Il peut s'agir d'un script CGI, ASP, JSP ou PHP qui génère des données dynamiquement ou à partir d'une base de données.

  • data- Ce paramètre facultatif représente un objet dont les propriétés sont sérialisées en paramètres correctement codés à transmettre à la demande. Si spécifié, la demande est effectuée à l'aide duPOSTméthode. Si omis, leGET méthode est utilisée.

  • callback- Une fonction de rappel appelée après que les données de réponse ont été chargées dans les éléments de l'ensemble correspondant. Le premier paramètre passé à cette fonction est le texte de réponse reçu du serveur et le second paramètre est le code d'état.

Exemple

Considérez le fichier HTML suivant avec un petit codage JQuery -

<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() {
            $("#driver").click(function(event){ $('#stage').load('/jquery/result.html');
            });
         });
      </script>
   </head>
	
   <body>
      <p>Click on the button to load /jquery/result.html file −</p>
		
      <div id = "stage" style = "background-color:cc0;">
         STAGE
      </div>
		
      <input type = "button" id = "driver" value = "Load Data" />
   </body>
</html>

Ici load() lance une requête Ajax vers l'URL spécifiée /jquery/result.htmlfichier. Après avoir chargé ce fichier, tout le contenu serait rempli à l'intérieur de <div> étiqueté avec l' étape ID . En supposant que notre fichier /jquery/result.html ne comporte qu'une seule ligne HTML -

<h1>THIS IS RESULT...</h1>

Lorsque vous cliquez sur le bouton donné, le fichier result.html est chargé.

Obtenir des données JSON

Il y aurait une situation où le serveur renverrait une chaîne JSON contre votre demande. Fonction utilitaire JQuerygetJSON() analyse la chaîne JSON renvoyée et met la chaîne résultante à la disposition de la fonction de rappel en tant que premier paramètre pour prendre des mesures supplémentaires.

Syntaxe

Voici la syntaxe simple pour getJSON() méthode -

[selector].getJSON( URL, [data], [callback] );

Voici la description de tous les paramètres -

  • URL - L'URL de la ressource côté serveur contactée via la méthode GET.

  • data - Un objet dont les propriétés servent de paires nom / valeur utilisées pour construire une chaîne de requête à ajouter à l'URL, ou une chaîne de requête préformatée et encodée.

  • callback- Une fonction appelée lorsque la requête se termine. La valeur de données résultant de la digestion du corps de la réponse en tant que chaîne JSON est transmise en tant que premier paramètre à ce rappel et l'état en tant que second.

Exemple

Considérez le fichier HTML suivant avec un petit codage JQuery -

<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() { $("#driver").click(function(event){
				
               $.getJSON('/jquery/result.json', function(jd) { $('#stage').html('<p> Name: ' + jd.name + '</p>');
                  $('#stage').append('<p>Age : ' + jd.age+ '</p>'); $('#stage').append('<p> Sex: ' + jd.sex+ '</p>');
               });
					
            });
         });
      </script>
   </head>
	
   <body>
      <p>Click on the button to load result.json file −</p>
		
      <div id = "stage" style = "background-color:#eee;">
         STAGE
      </div>
		
      <input type = "button" id = "driver" value = "Load Data" />
   </body>
</html>

Voici la méthode de l'utilitaire JQuery getJSON() lance une requête Ajax vers l'URL spécifiée result.jsonfichier. Après le chargement de ce fichier, tout le contenu serait passé à la fonction de rappel qui serait finalement peuplée à l'intérieur de <div> étiqueté avec l' étape ID . En supposant que notre fichier result.json a le contenu au format json suivant -

{
   "name": "Zara Ali",
   "age" : "67",
   "sex": "female"
}

Lorsque vous cliquez sur le bouton donné, le fichier result.json est chargé.

Transmission de données au serveur

Plusieurs fois, vous collectez les entrées de l'utilisateur et vous les transmettez au serveur pour un traitement ultérieur. JQuery AJAX a rendu assez facile la transmission des données collectées au serveur en utilisantdata paramètre de toute méthode Ajax disponible.

Exemple

Cet exemple montre comment transmettre l'entrée utilisateur à un script de serveur Web qui renverrait le même résultat et que nous l'imprimerions -

<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() { $("#driver").click(function(event){
               var name = $("#name").val(); $("#stage").load('/jquery/result.php', {"name":name} );
            });
         });
      </script>
   </head>
	
   <body>
      <p>Enter your name and click on the button:</p>
      <input type = "input" id = "name" size = "40" /><br />
		
      <div id = "stage" style = "background-color:cc0;">
         STAGE
      </div>
		
      <input type = "button" id = "driver" value = "Show Result" />
   </body>
</html>

Voici le code écrit en result.php script -

<?php
   if( $_REQUEST["name"] ){ $name = $_REQUEST['name']; echo "Welcome ". $name;
   }
?>

Vous pouvez maintenant entrer n'importe quel texte dans la zone de saisie donnée, puis cliquer sur le bouton "Afficher le résultat" pour voir ce que vous avez entré dans la zone de saisie.

Méthodes JQuery AJAX

Vous avez vu le concept de base d'AJAX en utilisant JQuery. Le tableau suivant répertorie toutes les méthodes JQuery AJAX importantes que vous pouvez utiliser en fonction de vos besoins de programmation -

Sr.No. Méthodes et description
1 jQuery.ajax (options)

Chargez une page distante à l'aide d'une requête HTTP.

2 jQuery.ajaxSetup (options)

Configurez les paramètres globaux pour les requêtes AJAX.

3 jQuery.get (url, [données], [rappel], [type])

Chargez une page distante à l'aide d'une requête HTTP GET.

4 jQuery.getJSON (url, [données], [rappel])

Chargez les données JSON à l'aide d'une requête HTTP GET.

5 jQuery.getScript (url, [rappel])

Charge et exécute un fichier JavaScript à l'aide d'une requête HTTP GET.

6 jQuery.post (url, [données], [rappel], [type])

Chargez une page distante à l'aide d'une requête HTTP POST.

sept load (url, [données], [rappel])

Chargez du HTML à partir d'un fichier distant et injectez-le dans le DOM.

8 sérialiser ()

Sérialise un ensemble d'éléments d'entrée en une chaîne de données.

9 serializeArray ()

Sérialise tous les formulaires et éléments de formulaire comme la méthode .serialize () mais renvoie une structure de données JSON avec laquelle vous pouvez travailler.

Événements JQuery AJAX

Vous pouvez appeler diverses méthodes JQuery au cours du cycle de vie de la progression de l'appel AJAX. Sur la base de différents événements / étapes, les méthodes suivantes sont disponibles -

Vous pouvez parcourir tous les événements AJAX .

Sr.No. Méthodes et description
1 ajaxComplete (rappel)

Attachez une fonction à exécuter chaque fois qu'une requête AJAX se termine.

2 ajaxStart (rappel)

Attachez une fonction à exécuter chaque fois qu'une requête AJAX commence et qu'aucune n'est déjà active.

3 ajaxError (rappel)

Attachez une fonction à exécuter chaque fois qu'une requête AJAX échoue.

4 ajaxSend (rappel)

Joindre une fonction à exécuter avant l'envoi d'une requête AJAX.

5 ajaxStop (rappel)

Attachez une fonction à exécuter chaque fois que toutes les requêtes AJAX sont terminées.

6 ajaxSuccess (rappel)

Attachez une fonction à exécuter chaque fois qu'une requête AJAX se termine avec succès.

jQuery fournit une interface très simple pour réaliser divers types d'effets étonnants. Les méthodes jQuery nous permettent d'appliquer rapidement les effets couramment utilisés avec une configuration minimale. Ce didacticiel couvre toutes les méthodes jQuery importantes pour créer des effets visuels.

Affichage et masquage des éléments

Les commandes pour afficher et masquer des éléments sont à peu près ce à quoi nous nous attendrions - show() pour montrer les éléments dans un ensemble enveloppé et hide() pour les cacher.

Syntaxe

Voici la syntaxe simple pour show() méthode -

[selector].show( speed, [callback] );

Voici la description de tous les paramètres -

  • speed - Une chaîne représentant l'une des trois vitesses prédéfinies ("lente", "normale" ou "rapide") ou le nombre de millisecondes pour exécuter l'animation (par exemple 1000).

  • callback- Ce paramètre facultatif représente une fonction à exécuter chaque fois que l'animation se termine; s'exécute une fois pour chaque élément animé contre.

Voici la syntaxe simple pour hide() méthode -

[selector].hide( speed, [callback] );

Voici la description de tous les paramètres -

  • speed - Une chaîne représentant l'une des trois vitesses prédéfinies ("lente", "normale" ou "rapide") ou le nombre de millisecondes pour exécuter l'animation (par exemple 1000).

  • callback- Ce paramètre facultatif représente une fonction à exécuter chaque fois que l'animation se termine; s'exécute une fois pour chaque élément animé contre.

Exemple

Considérez le fichier HTML suivant avec un petit codage JQuery -

<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() { $("#show").click(function () {
               $(".mydiv").show( 1000 ); }); $("#hide").click(function () {
               $(".mydiv").hide( 1000 );
            });
				
         });
      </script>
		
      <style>
         .mydiv{ 
            margin:10px;
            padding:12px; 
            border:2px solid #666; 
            width:100px; 
            height:100px;
         }
      </style>
   </head>
	
   <body>
      <div class = "mydiv">
         This is a SQUARE
      </div>

      <input id = "hide" type = "button" value = "Hide" />   
      <input id = "show" type = "button" value = "Show" />
   </body>
</html>

Cela produira le résultat suivant -

Basculer les éléments

jQuery fournit des méthodes pour basculer l'état d'affichage des éléments entre révélé ou masqué. Si l'élément est initialement affiché, il sera masqué; s'il est caché, il sera affiché.

Syntaxe

Voici la syntaxe simple de l'un des toggle() méthodes -

[selector]..toggle([speed][, callback]);

Voici la description de tous les paramètres -

  • speed - Une chaîne représentant l'une des trois vitesses prédéfinies ("lente", "normale" ou "rapide") ou le nombre de millisecondes pour exécuter l'animation (par exemple 1000).

  • callback- Ce paramètre facultatif représente une fonction à exécuter chaque fois que l'animation se termine; s'exécute une fois pour chaque élément animé contre.

Exemple

Nous pouvons animer n'importe quel élément, comme un simple <div> contenant une image -

<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() {
            $(".clickme").click(function(event){ $(".target").toggle('slow', function(){
                  $(".log").text('Transition Complete');
               });
            });
         });
      </script>
		
      <style>
         .clickme{ 
            margin:10px;
            padding:12px; 
            border:2px solid #666; 
            width:100px; 
            height:50px;
         }
      </style>
   </head>
	
   <body>
      <div class = "content">
         <div class = "clickme">Click Me</div>
         <div class = "target">
            <img src = "./images/jquery.jpg" alt = "jQuery" />
         </div>
         <div class = "log"></div>
      </div>
   </body>
</html>

Cela produira le résultat suivant -

Méthodes d'effet JQuery

Vous avez vu le concept de base des effets jQuery. Le tableau suivant répertorie toutes les méthodes importantes pour créer différents types d'effets -

Sr.No. Méthodes et description
1 animer (paramètres, [durée, accélération, rappel])

Une fonction pour créer des animations personnalisées.

2 fadeIn (vitesse, [rappel])

Fondu dans tous les éléments correspondants en ajustant leur opacité et en déclenchant un rappel facultatif après la fin.

3 fadeOut (vitesse, [rappel])

Effacez tous les éléments correspondants en ajustant leur opacité à 0, puis en définissant l'affichage sur «aucun» et en déclenchant un rappel facultatif après la fin.

4 fadeTo (vitesse, opacité, rappel)

Fade l'opacité de tous les éléments correspondants à une opacité spécifiée et déclenche un rappel facultatif après la fin.

5 cacher( )

Masque chacun des éléments correspondants s'ils sont affichés.

6 cacher (vitesse, [rappel])

Masquez tous les éléments correspondants à l'aide d'une animation élégante et déclenchez un rappel facultatif après la fin.

sept spectacle( )

Affiche chacun des ensembles d'éléments correspondants s'ils sont masqués.

8 show (vitesse, [rappel])

Affichez tous les éléments correspondants en utilisant une animation élégante et en déclenchant un rappel facultatif après la fin.

9 slideDown( speed, [callback] )

Reveal all matched elements by adjusting their height and firing an optional callback after completion.

10 slideToggle( speed, [callback] )

Toggle the visibility of all matched elements by adjusting their height and firing an optional callback after completion.

11 slideUp( speed, [callback] )

Hide all matched elements by adjusting their height and firing an optional callback after completion.

12 stop( [clearQueue, gotoEnd ])

Stops all the currently running animations on all the specified elements.

13 toggle( )

Toggle displaying each of the set of matched elements.

14 toggle( speed, [callback] )

Toggle displaying each of the set of matched elements using a graceful animation and firing an optional callback after completion.

15 toggle( switch )

Toggle displaying each of the set of matched elements based upon the switch (true shows all elements, false hides all elements).

16 jQuery.fx.off

Globally disable all animations.

Effets basés sur la bibliothèque de l'interface utilisateur

Pour utiliser ces effets, vous pouvez soit télécharger la dernière bibliothèque d'interface utilisateur jQuery jquery-ui-1.11.4.custom.zipà partir de la bibliothèque d'interface utilisateur jQuery ou utilisez Google CDN pour l'utiliser de la même manière que nous l'avons fait pour jQuery.

Nous avons utilisé Google CDN pour l'interface utilisateur jQuery en utilisant l'extrait de code suivant dans la page HTML afin de pouvoir utiliser l'interface utilisateur jQuery -

<head>
   <script src = "https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.3/jquery-ui.min.js">
   </script>
</head>
Sr.No. Méthodes et description
1 Aveugle

Aveugle l'élément ou le montre en l'aveuglant.

2 Rebondir

Fait rebondir l'élément verticalement ou horizontalement n fois.

3 Agrafe

Permet d'activer ou de désactiver l'élément, verticalement ou horizontalement.

4 Laissez tomber

Supprime l'élément ou l'affiche en le déposant.

5 Exploser

Décompose l'élément en plusieurs morceaux.

6 Plier

Plie l'élément comme un morceau de papier.

sept Surligner

Met en évidence l'arrière-plan avec une couleur définie.

8 Bouffée

Les animations d'échelle et de fondu créent l'effet de bouffée.

9 Palpiter

Fait pulser l'opacité de l'élément plusieurs fois.

dix Échelle

Réduisez ou augmentez un élément d'un facteur de pourcentage.

11 Secouer

Secoue l'élément n fois verticalement ou horizontalement.

12 Taille

Redimensionnez un élément à une largeur et une hauteur spécifiées.

13 Faire glisser

Fait glisser l'élément hors de la fenêtre.

14 Transfert

Transfère le contour d'un élément vers un autre.

Les interactions peuvent être ajoutées à n'importe quel élément des comportements de base basés sur la souris. En utilisant les interactions, nous pouvons créer des listes triables, des éléments redimensionnables, des comportements de glisser-déposer. Les interactions constituent également d'excellents blocs de construction pour des widgets et des applications plus complexes.

Sr.No. Interactions et description
1 Glisser capable

Activez la fonctionnalité de glisser sur n'importe quel élément DOM.

2 Drop capable

Activez n'importe quel élément DOM pour pouvoir être déposé.

3 Redimensionner capable

Permettre à tout élément DOM d'être redimensionnable.

4 Sélectionnez capable

Permettre à un élément DOM (ou groupe d'éléments) d'être sélectionnable.

5 Trier capable

Permettre à un groupe d'éléments DOM d'être triable.

un widget d'interface utilisateur jQuery est un plug-in jQuery spécialisé. En utilisant un plug-in, nous pouvons appliquer des comportements aux éléments. Cependant, les plug-ins ne disposent pas de certaines fonctionnalités intégrées, telles qu'un moyen d'associer des données à ses éléments, d'exposer des méthodes, de fusionner des options avec des valeurs par défaut et de contrôler la durée de vie du plug-in.

Sr.No. Widgets et description
1 Accordéon

Activez pour réduire le contenu, qui est divisé en sections logiques.

2 Saisie automatique

Activer pour fournit les suggestions pendant que vous tapez dans le champ.

3 Bouton

Button est une entrée de type submit et une ancre.

4 Sélecteur de date

Il s'agit d'ouvrir un calendrier interactif dans une petite superposition.

5 Dialogue

Les boîtes de dialogue sont l'un des moyens les plus intéressants de présenter des informations sur une page HTML.

6 Menu

Le menu affiche la liste des éléments.

sept Barre de progression

Il montre les informations de progression.

8 Sélectionnez le menu

Activer un style capable de sélectionner des éléments / éléments.

9 Glissière

Le curseur de base est horizontal et possède une seule poignée qui peut être déplacée avec la souris ou en utilisant les touches fléchées.

dix Fileur

Il fournit un moyen rapide de sélectionner une valeur dans un ensemble.

11 Onglets

Il est utilisé pour permuter entre le contenu divisé en sections logiques.

12 Info-bulle

Il fournit des conseils aux utilisateurs.

Jquery a deux thèmes de style différents comme A et B, chacun avec des couleurs différentes pour les boutons, les barres, les blocs de contenu, etc.

La syntaxe du thème de requête J comme indiqué ci-dessous -

<div data-role = "page" data-theme = "a|b">

Un exemple de thème simple comme indiqué ci-dessous -

<!DOCTYPE html>
<html>
   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1">
      <link rel = "stylesheet" 
         href = "https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css">
			
      <script src = "https://code.jquery.com/jquery-1.11.3.min.js">
      </script>
      <script src = "https://code.jquery.com/jquery-1.11.3.min.js">
      </script>
      <script 
         src = "https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js">
      </script>
   </head>
	
   <body>
      <div data-role = "page" id = "pageone" data-theme = "a">
        <div data-role = "header">
            <h1>Tutorials Point</h1>
         </div>

         <div data-role = "main" class = "ui-content">
			
            <p>Text link</p>
            <a href = "#">A Standard Text Link</a>
            <a href = "#" class = "ui-btn">Link Button</a>
            <p>A List View:</p>
				
            <ul data-role = "listview" data-autodividers = "true" data-inset = "true">
               <li><a href = "#">Android </a></li>
               <li><a href = "#">IOS</a></li>
            </ul>
				
            <label for = "fullname">Input Field:</label>
            <input type = "text" name = "fullname" id = "fullname" 
               placeholder = "Name..">    
            <label for = "switch">Toggle Switch:</label>
				
            <select name = "switch" id = "switch" data-role = "slider">
               <option value = "on">On</option>
               <option value = "off" selected>Off</option>
            </select>
				
         </div>

         <div data-role = "footer">
            <h1>Tutorials point</h1>
         </div>
      </div>
   </body>
</html>

Cela devrait produire le résultat suivant -

Un exemple de thème simple de B comme indiqué ci-dessous -

<!DOCTYPE html>
<html>
   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1">
      <link rel = "stylesheet" 
         href = "https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css">
      <script src = "https://code.jquery.com/jquery-1.11.3.min.js">
      </script>
      <script src = "https://code.jquery.com/jquery-1.11.3.min.js">
      </script>
      <script 
         src = "https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js">
      </script>
   </head>
	
   <body>
      <div data-role = "page" id = "pageone" data-theme = "b">
        <div data-role = "header">
            <h1>Tutorials Point</h1>
         </div>

         <div data-role = "main" class = "ui-content">
            <p>Text link</p>
            <a href = "#">A Standard Text Link</a>
            <a href = "#" class = "ui-btn">Link Button</a>
            <p>A List View:</p>
				
            <ul data-role = "listview" data-autodividers = "true" data-inset = "true">
               <li><a href = "#">Android </a></li>
               <li><a href = "#">IOS</a></li>
            </ul>
				
            <label for = "fullname">Input Field:</label>
            <input type = "text" name = "fullname" id = "fullname" 
               placeholder = "Name..">    
            <label for = "switch">Toggle Switch:</label>
				
            <select name = "switch" id = "switch" data-role = "slider">
               <option value = "on">On</option>
               <option value = "off" selected>Off</option>
            </select>
				
         </div>

         <div data-role = "footer">
            <h1>Tutorials point</h1>
         </div>
      </div>
   </body>
</html>

Cela devrait produire le résultat suivant -

Jquery fournit plusieurs utilitaires au format $ (espace de nom). Ces méthodes sont utiles pour effectuer les tâches de programmation. Quelques-unes des méthodes utilitaires sont illustrées ci-dessous.

$ .trim ()

$ .trim () est utilisé pour supprimer les espaces de début et de fin

$.trim( "    lots of extra whitespace    " );

$ .chaque ()

$ .each () est utilisé pour itérer sur des tableaux et des objets

$.each([ "foo", "bar", "baz" ], function( idx, val ) {
   console.log( "element " + idx + " is " + val );
});
 
$.each({ foo: "bar", baz: "bim" }, function( k, v ) {
   console.log( k + " : " + v );
});

.each () peut être appelé sur une sélection pour itérer sur les éléments contenus dans la sélection. .each (), et non $ .each (), doit être utilisé pour parcourir les éléments d'une sélection.

$ .inArray ()

$ .inArray () est utilisé pour Renvoie l'index d'une valeur dans un tableau, ou -1 si la valeur n'est pas dans le tableau.

var myArray = [ 1, 2, 3, 5 ];
 
if ( $.inArray( 4, myArray ) !== -1 ) {
   console.log( "found it!" );
}

$ .extend ()

$ .extend () est utilisé pour Modifie les propriétés du premier objet en utilisant les propriétés des objets suivants.

var firstObject = { foo: "bar", a: "b" };
var secondObject = { foo: "baz" };
 
var newObject = $.extend( firstObject, secondObject );
 
console.log( firstObject.foo ); 
console.log( newObject.foo );

$ .proxy ()

$ .proxy () est utilisé pour Renvoie une fonction qui s'exécutera toujours dans la portée fournie - c'est-à-dire définit la signification de ceci à l'intérieur de la fonction passée au deuxième argument

var myFunction = function() {
   console.log( this );
};

var myObject = {
   foo: "bar"
};
 
myFunction(); // window
 
var myProxyFunction = $.proxy( myFunction, myObject );
 
myProxyFunction();

$ .browser

$ .browser est utilisé pour donner des informations sur les navigateurs

jQuery.each( jQuery.browser, function( i, val ) {
   $( "<div>" + i + " : <span>" + val + "</span>" )
   .appendTo( document.body );
});

$ .contains ()

$ .contains () est utilisé pour retourner true si l'élément DOM fourni par le deuxième argument est un descendant de l'élément DOM fourni par le premier argument, qu'il s'agisse d'un enfant direct ou imbriqué plus profondément.

$.contains( document.documentElement, document.body ); $.contains( document.body, document.documentElement );

$ .data ()

$ .data () est utilisé pour donner les informations sur les données

<html lang = "en">
   <head>
      <title>jQuery.data demo</title>
      <script src = "https://code.jquery.com/jquery-1.10.2.js">
      </script>
   </head>
	
   <body>
      <div>
         The values stored were <span></span>
            and <span></span>
      </div>
 
      <script>
         var div = $( "div" )[ 0 ]; jQuery.data( div, "test", { first: 25, last: "tutorials" }); $( "span:first" ).text( jQuery.data( div, "test" ).first );
         $( "span:last" ).text( jQuery.data( div, "test" ).last );
      </script>
   </body>
</html>

Une sortie serait la suivante

The values stored were 25 and tutorials

$ .fn.extend ()

$ .fn.extend () est utilisé pour étendre le prototype jQuery

<html lang = "en">
   <head>
      <script src = "https://code.jquery.com/jquery-1.10.2.js">
      </script>
   </head>
	
   <body>
      <label><input type = "checkbox" name = "android"> 
         Android</label>
      <label><input type = "checkbox" name = "ios"> IOS</label>
 
      <script>
         jQuery.fn.extend({
			
            check: function() {
               return this.each(function() {
                  this.checked = true;
               });
            },
            uncheck: function() {
               return this.each(function() {
                  this.checked = false;
               });
            }
         });
 
         // Use the newly created .check() method
         $( "input[type = 'checkbox']" ).check();
			
      </script>
   </body>
</html>

Il fournit la sortie comme indiqué ci-dessous -

$ .isWindow ()

$ .isWindow () est utilisé pour reconnaître la fenêtre

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery.isWindow demo</title>
      <script src = "https://code.jquery.com/jquery-1.10.2.js">
      </script>
   </head>
	
   <body>
      Is 'window' a window? <b></b>
 
      <script>
         $( "b" ).append( "" + $.isWindow( window ) );
      </script>
   </body>
</html>

Il fournit la sortie comme indiqué ci-dessous -

$ .now ()

Il renvoie un nombre qui représente l'heure actuelle

(new Date).getTime()

$ .isXMLDoc ()

$ .isXMLDoc () vérifie si un fichier est un xml ou non

jQuery.isXMLDoc( document )
jQuery.isXMLDoc( document.body )

$ .globalEval ()

$ .globalEval () est utilisé pour exécuter le javascript globalement

function test() {
   jQuery.globalEval( "var newVar = true;" )
}
test();

$ .dequeue ()

$ .dequeue () est utilisé pour exécuter la fonction suivante dans la file d'attente

<!doctype html>
<html lang = "en">
   <head>
      <meta charset = "utf-8">
      <title>jQuery.dequeue demo</title>
		
      <style>
         div {
            margin: 3px;
            width: 50px;
            position: absolute;
            height: 50px;
            left: 10px;
            top: 30px;
            background-color: green;
            border-radius: 50px;
         }
         div.red {
            background-color: blue;
         }
      </style>
		
      <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>
   </head>

   <body>
      <button>Start</button>
      <div></div>
 
      <script>
         $( "button" ).click(function() {
            $( "div" ) .animate({ left: '+ = 400px' }, 2000 ) .animate({ top: '0px' }, 600 ) .queue(function() { $( this ).toggleClass( "red" );
               $.dequeue( this );
            })
				
            .animate({ left:'10px', top:'30px' }, 700 );
         });
      </script>
   </body>
</html>

Il fournit la sortie comme indiqué ci-dessous -