Maison  >  Article  >  interface Web  >  Introduction à la façon d'obtenir divers nœuds dom en javascript

Introduction à la façon d'obtenir divers nœuds dom en javascript

伊谢尔伦
伊谢尔伦original
2017-07-18 15:37:201692parcourir

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.

1. Obtenir via le nœud de document de niveau supérieur :
(1) document.getElementById(elementId) : Cette méthode peut obtenir avec précision les informations requises. via l’ID de l’élément node 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 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. Passer par 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 on combine les deux, on obtiendra un effet plus excitant, à savoir : parentObj.firstChild.lastChild.lastChild...
(3) parentObj.childNodes : Obtenu Vous connaissez le tableau des nœuds enfants 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) NeighbourNode.previousSibling : Obtenez le nœud précédent du nœud connu (neighbourNode) Cet attribut semble être le même que le précédent firstChild et). lastChild. 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 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 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

Code d'opération :

<table> 
<tr> 
<td id="TEST"> 
<input type="submit" value="确定"> 
<input type="button" value="取消"> 
</td> 
</tr> 
</table>

Testé :

var td= document.getElementById("TEST"); 
alert(td.childNodes.length);结果为4

JS中,空格也是作为一个文本节点,而两个input元素后面都有空格 
所以都作为一个文本节点,所以结果为4 
删除空格后结果为2 
为了处理里面的空格节点,用以下函数来处理 

function cleanWhitespace(element) 
{ 
for(var i=0; i<element.childNodes.length; i++) 
{ 
var node = element.childNodes[i]; 
if(node.nodeType == 3 && !/\S/.test(node.nodeValue)) 
{ 
node.parentNode.removeChild(node); 
} 
} 
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn