Avant de pouvoir commencer à manipuler le DOM, il faut bien comprendre qu’est ce que c’est et comment il fonctionne. Le DOM (Document Objet Model) indique comment les navigateurs doivent créer un modèle d’une page HTML et comment le Javascript peut accéder et mettre à jour le contenu de ce modèle, Le modèle représente un arbre dont les éléments sont relié les un aux autres. il est stocké dans la mémoire du navigateur pendant que celui-ci charge la page. Le DOM se compose en 4 types de nœuds.
Cet article peut être sujet à des mises à jour
Si vous avez des questions ou bien des remarques, n’hésitez pas à laisser un commentaire.
Document
Le noeud document représente le point de départ, c’est à partir de ce noeud qu’on accède à l’ensemble des éléments du DOM. Il représente également l’objet Document qui fournit diverses méthodes pour accéder aux éléments. ( ex : document.querySelector(‘div.exemple’);
)
Élément
Les éléments HTML décrivent la structure d’une page HTML. Pour accéder à l’arbre DOM, commencez par rechercher des éléments via Document. Une fois que vous avez trouvé l’élément que vous voulez, alors vous pouvez accéder à ses noeuds de texte et d’attribut.
Attribut
Les balises d’ouverture des éléments HTML peuvent contenir des attributs ( exemple : id, class, … ) et ceux-ci sont représentés par des noeuds d’attributs dans l’arbre DOM. Les noeuds d’attribut ne sont pas des enfants de l’élément qui les porte. Ils font partie de cet élément et ne peuvent eux-même pas avoir d’enfant. Une fois que vous accédez à un élément, il existe des méthodes et des propriétés JavaScript spécifiques pour lire ou modifier les attributs de cet élément.
Texte
Comme pour le noeud Attribut, vous pouvez accéder à un noeud texte par l’intermédiaire d’un noeud élément et comme pour le noeud attribut, les nœuds de texte ne peuvent pas avoir d’enfants.
Accéder aux éléments
Afin de pouvoir modifier un élément, nous devons d’abord pouvoir y accéder, pour cela ils existent de nombreuses méthodes qui permettent de naviguer à travers le dom et le modifier.
Sélectionnez un élément
getElementByld()
: Permet d’accéder à un élément par l’intermédiaire de son attribut ID.querySelector()
: Permet de retourner un élément en fonction d’un sélecteur CSS.
Sélectionnez plusieurs éléments
Ces méthodes récupérer nos éléments sous forme d’un tableau
getElementsByClassName()
: Permet de retourner plusieurs éléments par l’intermédiaire d’une classe.getElementsByTagName()
: Permet de retourner plusieurs éléments par l’intermédiaire d’une balise HTML ( ex:<div>
) .querySelectorAll()
: Permet de retourner plusieurs éléments en fonction d’un sélecteur CSS.
Passer d’un noeud à un autre
parentNode
: Renvoie l’élément parent de l’élément courant.childNodes
: Renvoie une liste d’enfants de l’élément courant.previousSibling
: Renvoie l’élément suivant de l’élément courant.nextSibling
: Renvoie l’élément précédent de l’élément courant.firstChild
: Renvoie le premier élément enfant de l’élément courant.lastChild
: Renvoie le dernier élément enfant de l’élément courant.
Manipuler les attributs
Une fois que vous avez accéder à votre élément vous avez accéder à ses attributs et valeurs avec différente méthodes pour les manipuler.
id
id
: Récupérer ou définit l’id de l’élément
Classe
className
: Récupère ou définit la classe de l’élément.classList
: Renvoie un tableau listant les classes de l’élémentadd
: Ajouter une classe dans la listeremove
: Enlever une classe de la listetoggle
: Ajouter/Enlever une classe (Alterne, l’ajoute si elle n’existe pas ou l’enlever si elle existe).contains
: Renvoie un boolean vrai si une classe est dans la liste.
Attributs en générale
hasAttribute()
: Renvoie un boolean vrai si un attribut existe dans l’élément courant.getAttribute()
: Retourne la valeur d’un élément.setAttribute()
: Ajouter un attribut et sa valeur en second argument dans l’élément.removeAttribute()
: Enlever un attribut dans l’élément.
Accéder aux valeurs.
nodeValue
: Permet de renvoyer le contenue d’un noeud, dans le cadre d’un paragraphe, renvoi son texte mais si le noeud est un attribut, renvoi la valeur de l’attribut.innerText
: récupère le texte sans prendre en compte le balisage..innerHTML
: récupère le texte ainsi que le balisage du noeud.textContent
: textContent le texte commeinnerText
ainsi que le<script>
et<style>
à l’inverse deinnerText
.
Ajouter des éléments en 3 étapes
Une des choses les plus important quand on manipule le DOM c’est de pouvoir créer de nouveaux éléments, on peut créer un élément complet en 3 étapes:
createElement()
: Vous commencez par créer un nouveau noeud d’élément à l’aide de la méthodecreateElement()
. Ce noeud élément est stocké dans une variable.var element= document.createElement("p");
createTextNode()
:createTextNode()
crée un nouveau nœud de texte. Encore une fois, le nœud est stocké dans une variable, il peut être ajouté au nœud élément en utilisant la méthodeappendChild()
.var texte = document.createTextNode("Lorem Ipsum");
appendChild()
: Maintenant que vous avez votre élément avec ou pas un contenu dans un nœud de texte, vous pouvez l’ajouter à l’arbre DOM à l’aide de cette méthode.var element = document.createElement('p'); var texte = document.createTextNode('Lorem Ipsum'); element.appendChild(texte); document.body.appendChild(element);
La méthode write
Peut être vous avez entendu parlez de la méthode document.write
pour créer un balisage et du texte dans un document toutefois cette méthode apporte de nombreux inconvénient et des problèmes car il ne fonctionne que lorsque la page est chargée initialement et après qu’il soit chargé, il peut causer différents problèmes.
- Écraser toute la page
- Ne pas ajouter le contenu à la page
- Créer une nouvelle page
Enlever un élément en 3 étapes
Comme pour ajouter un élément dans le DOM, il nous arrivent de devoir supprimer un élément du DOM.
- Pour ce faire, vous devez stocker dans une variable la variable l’élément que vous voulez supprimer.
var removeElement= document.getElementById('monId');
- Ensuite, à partir de cette variable, on doit accéder à l’élément parent via la méthode
parentNode
.var parentElement = removeElement.parentNode;
- Avec cette seconde variable, vous allez pouvoir supprimer l’élément que vous avez stocké durant la première étape.
var removeElement= document.getElementById('monId'); var parentElement = removeElement.parentNode; parentElement .removeChild(removeElement);