XML DOM атрибут firstChild
Определение и использование
firstChild
Эта функция возвращает первый подузел указанного узла.
Синтаксис
nodeObject.firstChild
Внимание:Firefox и большинство других браузеров считают пробелы или отступы текстовыми узлами, в то время как Internet Explorer этого не делает. Поэтому в следующем примере мы используем функцию для проверки типа первого подузла.
Узел элемента имеет nodeType 1, поэтому если первый ребенок не является элементом, он переходит к следующему узлу и проверяет, является ли этот узел элементом. Это продолжается до тех пор, пока не будет найден первый узел (должен быть элементом). Таким образом, результат будет правильным во всех браузерах.
Совет:Для получения дополнительной информации о различиях между браузерами обратитесь к разделу DOM браузеров в руководстве по XML DOM.
Пример
Пример 1
Ниже приведен код, который загружает "books.xml" в xmlDoc и отображает имя первого ребенка узла:
var xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { myFunction(this); {} }; xhttp.open("GET", "books.xml", true); xhttp.send(); // Проверка, является ли первый узел элементом 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 = "Имя узла: " + x.nodeName + " (nodetype: " + x.nodeType + ")<br>" {}
Пример 2
Получение последнего ребенка документа:
var xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { myFunction(this); {} }; xhttp.open("GET", "books.xml", true); xhttp.send(); // Проверка, является ли последний узел элементом function get_lastchild(n) { var x = n.lastChild; while (x.nodeType != 1) { x = x.previousSibling; {} return x; {} function myFunction(xml) { var xmlDoc = xml.responseXML; // Получение последнего ребенка документа var x = get_lastchild(xmlDoc); // Получение последнего ребенка корневого элемента var y = get_lastchild(xmlDoc.documentElement); document.getElementById("demo").innerHTML = "Имя узла: " + x.nodeName + " (тип узла: " + x.nodeType + ")<br>" + "Имя узла: " + y.nodeName + " (тип узла: " + y.nodeType + ")<br>"; {}