Атрибут nextSibling в XML DOM
Определение и использование
nextSibling
Атрибут возвращает следующий同级 узел выбранного элемента (следующий узел в том же уровне дерева).
Если такого узла не существует, то этот атрибут возвращает null.
Синтаксис
elementNode.nextSibling
Примечание:Firefox и большинство других браузеров считают пробелы или переводы строк текстовыми узлами, в то время как Internet Explorer этого не делает. Поэтому в следующем примере мы используем функцию для проверки типа узла следующего братского узла.
Элементный узел nodeType равен 1, поэтому если следующий братский узел не является элементным узлом, он переходит к следующему узлу и проверяет, является ли этот узел элементным узлом. Это продолжится, пока не будет найден следующий同级 узел (должен быть элементным узлом). Таким образом, результат будет правильным во всех браузерах.
Совет:Для получения更多信息 о различиях между браузерами обратитесь к разделу DOM браузеров в учебнике XML DOM.
Пример
Пример 1
Следующий код загружает "books.xml" в xmlDoc и получает следующий同级 узел первого <title> элемента:
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_nextsibling(n) { var x = n.nextSibling; while (x.nodeType != 1) { x = x.nextSibling; {} return x; {} function myFunction(xml) { var xmlDoc = xml.responseXML; var x = xmlDoc.getElementsByTagName("title")[0]; var y = get_nextsibling(x); document.getElementById("demo").innerHTML = x.nodeName + " = " + x.childNodes[0].nodeValue + "<br>Следующий брат: " + y.nodeName + " = " + y.childNodes[0].nodeValue; {}
Пример 2
Использование метода previousSibling для получения предыдущего同级 узла:
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_previoussibling(n) { var x = n.previousSibling; while (x.nodeType != 1) { x = x.previousSibling; {} return x; {} function myFunction(xml) { var xmlDoc = xml.responseXML; var x = xmlDoc.getElementsByTagName("author")[0]; var y = get_previoussibling(x); document.getElementById("demo").innerHTML = x.nodeName + " = " + x.childNodes[0].nodeValue + "<br>Предыдущий брат: " + y.nodeName + " = " + y.childNodes[0].nodeValue; {}