XML DOM getNamedItem() 方法

定義和用法

getNamedItem() 方法返回擁有特定名稱的節點(來自 namedNodeMap)。

語法

namedNodeMap.getNamedItem(nodeName)

參數

參數 描述
nodeName 必需。字符串。要返回的節點的名稱。

技術細節

DOM 版本: Core Level 1
返回值:

Node 對象。擁有指定名稱的節點。

如果未標識映射中的任何節點,則返回 null。

實例

下面的代碼將 "books.xml" 加載到 xmlDoc 中,循環遍歷 <book> 元素,并打印 category 屬性的值:

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 myFunction(xml) {
    var x, i, att, xmlDoc, txt;
    xmlDoc = xml.responseXML;
    txt = "";
    x = xmlDoc.getElementsByTagName('book');
    for (i = 0; i < x.length; i++) {
        att = x.item(i).attributes.getNamedItem("category");
        txt += att.value + "<br>";
    }
    document.getElementById("demo").innerHTML = txt;
}

親自試一試

例子 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 myFunction(xml) {
    var x, i, attlist, att, xmlDoc, txt;
    xmlDoc = xml.responseXML;
    txt = "";
    x = xmlDoc.getElementsByTagName("book");
    // 更改 category 屬性的屬性值
    for (i = 0; i < x.length; i++) { 
        attlist = x.item(i).attributes;
        att = attlist.getNamedItem("category");
        att.value = "BESTSELLER";
    }
    // 輸出所有 title 和 edition
    for (i = 0; i < x.length; i++) { 
        txt += x[i].getAttribute("category") + "<br>";
    }
    document.getElementById("demo").innerHTML = txt; 
}

親自試一試

瀏覽器支持

Chrome Edge Firefox Safari Opera
Chrome Edge Firefox Safari Opera
支持 支持 支持 支持 支持

所有主流瀏覽器都支持 getNamedItem() 方法。

注釋:Internet Explorer 8 及更早版本不支持此方法。