Maison > Article > interface Web > Résumé de 11 façons d'obtenir des éléments DOM dans les astuces JavaScript_javascript
Dans le développement d'applications Web, notamment de programmes Web 2.0, il est souvent nécessaire d'obtenir un élément dans la page puis de mettre à jour le style, le contenu, etc. Comment obtenir les éléments à mettre à jour est le premier problème à résoudre. Heureusement, il existe de nombreuses façons d'obtenir des nœuds en utilisant JavaScript. Voici un bref résumé (la méthode suivante a été testée dans IE7 et Firefox2.0.0.11) :
1. Obtenir via le nœud de document de niveau supérieur :
(1) document.getElementById(elementId) : Cette méthode peut obtenir avec précision l'élément requis via l'ID du nœud. C'est une méthode relativement simple et rapide. Si la page contient plusieurs nœuds avec le même ID, seul le premier nœud sera renvoyé.
De nos jours, de nombreuses bibliothèques JavaScript telles que prototype et Mootools sont apparues, qui fournissent une méthode plus simple : $(id), et le paramètre est toujours l'identifiant du nœud. Cette méthode peut être considérée comme une autre façon d'écrire document.getElementById(), mais la fonction de $() est plus puissante. Pour une utilisation spécifique, veuillez vous référer à leurs documents API respectifs.
(2) document.getElementsByName(elementName) : Cette méthode obtient le nœud par son nom. Comme le montre le nom, cette méthode ne renvoie pas un élément de nœud, mais un tableau de nœuds portant le même nom. Ensuite, nous pouvons parcourir un certain attribut du nœud pour déterminer s’il s’agit du nœud requis.
Par exemple : en HTML, la case à cocher et la radio utilisent la même valeur d'attribut de nom pour identifier les éléments d'un groupe. Si nous voulons obtenir l'élément sélectionné maintenant, nous obtenons d'abord l'élément mélangé, puis effectuons une boucle pour déterminer si la valeur d'attribut vérifiée du nœud est vraie.
(3) document.getElementsByTagName(tagName) : Cette méthode obtient le nœud via son Tag. Cette méthode renvoie également un tableau. Par exemple : document.getElementsByTagName('A') renverra tous les nœuds de lien hypertexte sur la page. Avant d'obtenir le nœud, le type du nœud est généralement connu, il est donc relativement simple d'utiliser cette méthode. Mais l'inconvénient est également évident, c'est-à-dire que le tableau renvoyé peut être très volumineux, ce qui fera perdre beaucoup de temps. Alors, cette méthode est-elle inutile ? Bien sûr que non. Cette méthode est différente des deux ci-dessus. Ce n'est pas une méthode propriétaire du nœud de document et peut également être appliquée à d'autres nœuds, qui seront mentionnés ci-dessous.
2. Obtenir via le nœud parent :
(1) parentObj.firstChild : Cette méthode peut être utilisée si le nœud est le premier nœud enfant d'un nœud connu (parentObj). Cet attribut peut être utilisé de manière récursive, c'est-à-dire qu'il prend en charge la forme parentObj.firstChild.firstChild.firstChild..., afin que des nœuds plus profonds puissent être obtenus.
(2) parentObj.lastChild : Évidemment, cet attribut sert à obtenir le dernier nœud enfant du nœud connu (parentObj). Comme firstChild, il peut également être utilisé de manière récursive.
À l'utilisation, si on combine les deux, on obtiendra un effet plus excitant, à savoir : parentObj.firstChild.lastChild.lastChild...
(3) parentObj.childNodes : obtenez le tableau de nœuds enfants d'un nœud connu, puis recherchez le nœud requis via une boucle ou une indexation.
Remarque : Après les tests, il a été constaté que sur IE7, ce qui est obtenu est le tableau des nœuds enfants directs, tandis que sur Firefox2.0.0.11, ce qui est obtenu est tous les nœuds enfants, y compris les nœuds enfants du nœud enfant. .
(4) parentObj.children : obtenez le tableau de nœuds enfants directs d'un nœud connu.
Remarque : après test, sur IE7, l'effet est le même que celui des childNodes, mais Firefox2.0.0.11 ne le prend pas en charge. C'est pourquoi j'utilise un style différent des autres méthodes. Son utilisation n’est donc pas recommandée.
(5) parentObj.getElementsByTagName(tagName) : La méthode d'utilisation ne sera pas décrite en détail. Elle renvoie un tableau de nœuds enfants de la valeur spécifiée parmi tous les nœuds enfants du nœud connu. Par exemple : parentObj.getElementsByTagName('A') renvoie tous les hyperliens dans les nœuds enfants connus.
3. Obtenir via les nœuds adjacents :
(1) NeighbourNode.previousSibling : Obtenez le nœud précédent du nœud connu (neighbourNode). Cet attribut semble être utilisé de manière récursive comme les précédents firstChild et lastChild.
(2) NeighbourNode.nextSibling : obtenez le nœud suivant du nœud connu (neighbourNode), prend également en charge la récursivité.
4. Obtenir via les nœuds enfants :
(1) childNode.parentNode : obtenez le nœud parent d'un nœud connu.
Les méthodes mentionnées ci-dessus ne sont que quelques méthodes de base. Si vous utilisez des bibliothèques JavaScript telles que Prototype, vous pouvez également obtenir d'autres méthodes différentes, comme l'obtention via la classe du nœud, etc. Cependant, si vous pouvez utiliser les méthodes ci-dessus de manière flexible, je pense que vous devriez être capable de gérer la plupart des programmes.