déclaration! ! , cet article est une réimpression de l'article de quelqu'un d'autre, car il s'est avéré être utilisé et semblait très pratique, alors je l'ai récupéré pour une utilisation future ! !
Merci à l'auteur original ! ! ! ,
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. de l'élément. 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é (la méthode suivante a été testée sous IE7 et Firefox2.0.0.11) :
1. Obtenez 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, il existe de nombreuses bibliothèques JavaScript telles que prototype et Mootools, 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 toutes deux la même valeur d'attribut de nom pour identifier les éléments au sein 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 sa balise. 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. Obtenez 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'usage, si nous combinons les deux, nous obtiendrons des résultats plus intéressants, à 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. Obtenez à partir des nœuds adjacents :
(1) NeighbourNode.previousSibling : récupère 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, telles que l'obtention via la classe du nœud, etc. Cependant, si vous pouvez utiliser de manière flexible les différentes méthodes ci-dessus, je pense que vous devriez être capable de gérer la plupart des programmes.
Notez qu'il s'agit d'un document reproduit : il est déconseillé d'obtenir le HTML Node via firstChild et lastChild. Parce que, selon le navigateur, firstChild peut renvoyer l'objet attribut de parentObj.