XML DOM FirstChild Property
❮ Obiekt dokumentu
Przykład
Poniższy fragment kodu ładuje " books.xml " do xmlDoc i wyświetla nazwę węzła oraz typ pierwszego węzła podrzędnego:
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
myFunction(this);
}
};
xhttp.open("GET", "books.xml", true);
xhttp.send();
// Check if the first node is an element node
function get_firstchild(n)
{
var x = n.firstChild;
while (x.nodeType
!= 1) {
x = x.nextSibling;
}
return x;
}
function myFunction(xml) {
var xmlDoc = xml.responseXML;
var x = get_firstchild(xmlDoc);
document.getElementById("demo").innerHTML =
"Nodename:
" + x.nodeName +
" (nodetype: " + x.nodeType + ")<br>";
}
Wynikiem powyższego kodu będzie:
Nodename: bookstore (nodetype: 1)
Definicja i użycie
Właściwość firstChild zwraca pierwszy węzeł podrzędny dokumentu.
Składnia
documentObject.firstChild
Wskazówki i uwagi
Uwaga: Firefox i większość innych przeglądarek traktuje puste odstępy lub nowe wiersze jako węzły tekstowe, Internet Explorer nie. Tak więc w poniższym przykładzie mamy funkcję, która sprawdza typ węzła pierwszego węzła potomnego.
Węzły elementu mają nodeType równy 1, więc jeśli pierwszy węzeł podrzędny nie jest węzłem elementu, przechodzi do następnego węzła i sprawdza, czy ten węzeł jest węzłem elementu. Trwa to do momentu znalezienia pierwszego węzła podrzędnego (który musi być węzłem elementu). W ten sposób wynik będzie poprawny we wszystkich przeglądarkach.
Wskazówka: aby dowiedzieć się więcej o różnicach między przeglądarkami, odwiedź nasz rozdział Przeglądarki DOM w naszym samouczku XML DOM.
Próbne wersje demonstracyjne
❮ Obiekt dokumentu