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 à l'aide de JavaScript. Voici un bref résumé (les méthodes suivantes ont été testées dans IE7 et Firefox2.0.0.11) :
1. document Acquisition de nœud :
(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 All hyperlink. nœuds 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. Passer par le nœud parent :
(1) parentObj.firstChild : Il peut être utilisé si le nœud est le premier nœud enfant d'un nœud connu ( parentObj) Cette méthode. 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 nous combinons les deux, nous obtiendrons un effet plus excitant, à savoir : parentObj.firstChild.lastChild.lastChild...
(3) parentObj.childNodes : Obtenez le Vous connaissez le tableau de l'enfant nœuds d'un nœud, puis vous pouvez trouver 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) NeighborNode.previousSibling : Obtenez le nœud précédent du nœud connu (neighbourNode). le précédent firstChild , lastChild semble pouvoir être utilisé de manière récursive.
(2) NeighbourNode.nextSibling : obtenez le nœud suivant du nœud connu (neighbourNode), prend également en charge la récursivité.
4. Obtenir via des 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 différentes méthodes ci-dessus de manière flexible, je pense que vous devriez être capable de gérer la plupart des programmes.