XML 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();
// 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>";
}
ผลลัพธ์ของโค้ดด้านบนจะเป็น:
Nodename: bookstore (nodetype: 1)
ความหมายและการใช้งาน
คุณสมบัติ firstChild ส่งคืนโหนดชายด์แรกของเอกสาร
ไวยากรณ์
documentObject.firstChild
เคล็ดลับและหมายเหตุ
หมายเหตุ: Firefox และเบราว์เซอร์อื่นๆ ส่วนใหญ่จะถือว่าช่องว่างสีขาวหรือบรรทัดใหม่เป็นโหนดข้อความ แต่ Internet Explorer จะไม่ดำเนินการ ในตัวอย่างด้านล่าง เรามีฟังก์ชันที่ตรวจสอบประเภทโหนดของโหนดย่อยแรก
โหนดองค์ประกอบมีโหนดประเภท 1 ดังนั้นหากโหนดย่อยแรกไม่ใช่โหนดองค์ประกอบ โหนดจะย้ายไปยังโหนดถัดไป และตรวจสอบว่าโหนดนี้เป็นโหนดองค์ประกอบหรือไม่ สิ่งนี้จะดำเนินต่อไปจนกว่าจะพบโหนดย่อยแรก (ซึ่งจะต้องเป็นโหนดองค์ประกอบ) ด้วยวิธีนี้ ผลลัพธ์จะถูกต้องในทุกเบราว์เซอร์
เคล็ดลับ:หากต้องการอ่านเพิ่มเติมเกี่ยวกับความแตกต่างระหว่างเบราว์เซอร์ โปรดไป ที่บท เบราว์เซอร์ DOM ของ เราในบทช่วยสอน XML DOM
ทดลองด้วยตัวเอง
❮ วัตถุเอกสาร