XML DOM lastChild 屬性

定義和用法

lastChild 屬性返回所選元素的最后一個子節點。

如果所選節點沒有子節點,則此屬性返回 NULL。

語法

elementNode.lastChild
Tips and Notes

注意:Firefox 和大多數其他瀏覽器會將空白或換行視為文本節點,而 Internet Explorer 不會。因此,在下面的例子中,我們用一個函數來檢查最后一個子節點的節點類型。

元素節點的 nodeType 為 1,因此如果最后一個子節點不是元素節點,它會移動到前一個節點,并檢查該節點是否是元素節點。這會一直持續到找到最后一個子節點(必須是元素節點)。這樣,結果在所有瀏覽器中都是正確的。

提示:如需了解有關瀏覽器之間差異的更多信息,請訪問 XML DOM 教程中的 DOM 瀏覽器章節。

實例

下面的代碼將 "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_lastchild(n) {
    var x = n.lastChild;
    while (x.nodeType != 1) {
        x = x.previousSibling;
    }
    return x;
}
function myFunction(xml) {
    var x, i, txt, firstNode, xmlDoc;
    xmlDoc = xml.responseXML;
    x = xmlDoc.documentElement;
    txt = "";
    firstNode = get_lastchild(x);
    for (i = 0; i < firstNode.childNodes.length; i++) {
        if (firstNode.childNodes[i].nodeType == 1) {
            // 僅處理元素節點
            txt += firstNode.childNodes[i].nodeName +
            " = " +
            firstNode.childNodes[i].childNodes[0].nodeValue + "<br>";
        }
    }
    document.getElementById("demo").innerHTML = txt;
}

親自試一試