Heim >Web-Frontend >js-Tutorial >So durchlaufen Sie den DOM-Dokumentbaum in JS

So durchlaufen Sie den DOM-Dokumentbaum in JS

php中世界最好的语言
php中世界最好的语言Original
2018-04-08 13:59:161742Durchsuche

Dieses Mal zeige ich Ihnen, wie Sie den DOMDokumentenbaum mit JS durchqueren und welche Vorsichtsmaßnahmen für das Durchqueren des DOM-Dokumentenbaums mit JS gelten. Hier ist ein praktischer Fall , lass uns einen Blick darauf werfen.

Das Beispiel in diesem Artikel beschreibt die Methode, mit der JS den DOM-Dokumentbaum durchläuft. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Einführung

Durchlaufen Sie den Dokumentbaum mithilfe des parentNode-Attributs firstChild Attribut, lastChild-Attribut, previousSibling-Attribut und nextSibling-Attribut zu erreichen.

1. parentNode-Attribut

Dieses Attribut gibt den übergeordneten Knoten des aktuellen Knotens zurück.

[pNode=]obj.parentNode

pNode: Dieser Parameter wird zum Speichern des übergeordneten Knotens verwendet. Wenn der übergeordnete Knoten nicht vorhanden ist, wird „null“ zurückgegeben.

2. firstChild Attribut

Dieses Attribut gibt den ersten untergeordneten Knoten des aktuellen Knotens zurück.

[cNode=]obj.firstChild

cNode: Dieser Parameter wird zum Speichern des ersten untergeordneten Knotens verwendet. Wenn er nicht vorhanden ist, wird „null“ zurückgegeben.

3. lastChild-Attribut

Dieses Attribut gibt den letzten untergeordneten Knoten des aktuellen Knotens zurück.

[cNode=]obj.lastChild

cNode: Dieser Parameter wird zum Speichern des letzten untergeordneten Knotens verwendet. Wenn er nicht vorhanden ist, wird „null“ zurückgegeben.

4. previousSibling Attribut

Dieses Attribut gibt den vorherigen Geschwisterknoten des aktuellen Knotens zurück.

[sNode=]obj.previousSibling

sNode: Dieser Parameter wird zum Speichern des vorherigen Geschwisterknotens verwendet. Wenn er nicht vorhanden ist, wird „null“ zurückgegeben.

5. nextSibling-Attribut

Dieses Attribut gibt den nächsten Geschwisterknoten des aktuellen Knotens zurück.

[sNode=]obj.nextSibling

sNode: Dieser Parameter wird zum Speichern des nächsten Geschwisterknotens verwendet. Wenn er nicht vorhanden ist, wird „null“ zurückgegeben.

Zweite Anwendung

Durchsuchen Sie den Dokumentbaum. Auf der Seite finden Sie den Namen, den Typ und die Nummer jedes Knotens des Dokuments über den entsprechenden Knotenwert.

Drei Codes

<head>
<title>遍历文档树</title>
</head>
<body >
<h3 id="h1">三号标题</h3>
<b>加粗内容</b>
<form name="frm" action="#" method="get">
节点名称:<input type="text" id="na"/><br />
节点类型:<input type="text" id="ty"/><br />
节点的值:<input type="text" id="va"/><br />
<input type="button" value="父节点" onclick="txt=nodeS(txt,&#39;parent&#39;);"/>
<input type="button" value="第一个子节点" onclick="txt=nodeS(txt,&#39;firstChild&#39;);"/>
<input type="button" value="最后一个子节点" onclick="txt=nodeS(txt,&#39;lastChild&#39;);"/><br>
<input name="button" type="button" onclick="txt=nodeS(txt,&#39;previousSibling&#39;);" value="前一个兄弟节点"/>
<input type="button" value="最后一个兄弟节点" onclick="txt=nodeS(txt,&#39;nextSibling&#39;);"/>
<input type="button" value="返回根节点" onclick="txt=document.documentElement;txtUpdate(txt);"/>
</form>
<script language="javascript">
<!--
function txtUpdate(txt)
{
 window.document.frm.na.value=txt.nodeName;
 window.document.frm.ty.value=txt.nodeType;
 window.document.frm.va.value=txt.nodeValue;
}
function nodeS(txt,nodeName)
{
switch(nodeName)
{
case"previousSibling":
if(txt.previousSibling)
{
 txt=txt.previousSibling;
}
else
 alert("无兄弟节点");
break;
case"nextSibling":
if(txt.nextSibling)
{
 txt=txt.nextSibling;
}
else
 alert("无兄弟节点");
break;
case"parent":
if(txt.parentNode)
{
 txt=txt.parentNode;
}
else
 alert("无父节点");
break;
case"firstChild":
if(txt.hasChildNodes())
{
 txt=txt.firstChild;
}
else
 alert("无子节点");
break;
case"lastChild":
if(txt.hasChildNodes())
{
 txt=txt.lastChild;
}
else
 alert("无子节点")
break;
}
 txtUpdate(txt);
return txt;
}
var txt=document.documentElement;
 txtUpdate(txt);
-->
</script>
</body>

Vier Laufergebnisse

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website.

Empfohlene Lektüre:

React implementiert die Datensynchronisierung von Mobiltelefonnummern

Wie konvertiert Babel die Syntax der ES6-Klasse?

Das obige ist der detaillierte Inhalt vonSo durchlaufen Sie den DOM-Dokumentbaum in JS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn