真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

XMLDOM是什么意思

本篇文章給大家分享的是有關(guān)XML DOM是什么意思,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

10年積累的做網(wǎng)站、網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)制作后付款的網(wǎng)站建設(shè)流程,更有富縣免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

XML 文檔對(duì)象模型定義訪問(wèn)和操作XML文檔的標(biāo)準(zhǔn)方法。

DOM 將 XML 文檔作為一個(gè)樹(shù)形結(jié)構(gòu),而樹(shù)葉被定義為節(jié)點(diǎn)。

什么是 XML DOM?

XML DOM 是:

  • 用于 XML 的標(biāo)準(zhǔn)對(duì)象模型

  • 用于 XML 的標(biāo)準(zhǔn)編程接口

  • 中立于平臺(tái)和語(yǔ)言

  • W3C 的標(biāo)準(zhǔn)

XML DOM 定義了所有 XML 元素的對(duì)象和屬性,以及訪問(wèn)它們的方法(接口)。

換句話說(shuō):

XML DOM 是用于獲取、更改、添加或刪除 XML 元素的標(biāo)準(zhǔn)。

XML DOM 節(jié)點(diǎn)

XML 文檔中的每個(gè)成分都是一個(gè)節(jié)點(diǎn)。

節(jié)點(diǎn)

根據(jù) DOM,XML 文檔中的每個(gè)成分都是一個(gè)節(jié)點(diǎn)。

DOM 是這樣規(guī)定的:

  • 整個(gè)文檔是一個(gè)文檔節(jié)點(diǎn)

  • 每個(gè) XML 標(biāo)簽是一個(gè)元素節(jié)點(diǎn)

  • 包含在 XML 元素中的文本是文本節(jié)點(diǎn)

  • 每一個(gè) XML 屬性是一個(gè)屬性節(jié)點(diǎn)

  • 注釋屬于注釋節(jié)點(diǎn)

DOM 實(shí)例

請(qǐng)看下面的 XML 文件 (books.xml):






  Harry Potter 
  J K. Rowling 
  2005 
  29.99 



  Everyday Italian 
  Giada De Laurentiis 
  2005 
  30.00 



  Learning XML 
  Erik T. Ray 
  2003 
  39.95 



  XQuery Kick Start 
  James McGovern 
  Per Bothner 
  Kurt Cagle 
  James Linn 
  Vaidyanathan Nagarajan 
  2003 
  49.99 


在上面的 XML 中,根節(jié)點(diǎn)是 。文檔中的所有其他節(jié)點(diǎn)都被包含在 中。

根節(jié)點(diǎn) 有四個(gè) 節(jié)點(diǎn)。

第一個(gè) 節(jié)點(diǎn)有四個(gè)節(jié)點(diǎn):, <author>, <year> 以及 <price>,其中每個(gè)節(jié)點(diǎn)都包含一個(gè)文本節(jié)點(diǎn),"Harry Potter", "J K. Rowling", "2005" 以及 "29.99"。</p><h3>文本總是存儲(chǔ)在文本節(jié)點(diǎn)中</h3><p>在 DOM 處理中一個(gè)普遍的錯(cuò)誤是,認(rèn)為元素節(jié)點(diǎn)包含文本。</p><p>不過(guò),元素節(jié)點(diǎn)的文本是存儲(chǔ)在文本節(jié)點(diǎn)中的。</p><p>在這個(gè)例子中:<em><year>2005</year></em>,元素節(jié)點(diǎn) <year>,擁有一個(gè)值為 "2005" 的文本節(jié)點(diǎn)。</p><p>"2005" <em>不是</em> <year> 元素的值!</p><p><strong>XML DOM 節(jié)點(diǎn)樹(shù)</strong></p><p><strong>XML DOM 把 XML DOM 文檔視為一棵節(jié)點(diǎn)樹(shù) (node-tree)。</strong></p><p><strong>樹(shù)中的所有節(jié)點(diǎn)彼此之間都有關(guān)系。</strong></p><h3>XML DOM 節(jié)點(diǎn)樹(shù)</h3><p>XML DOM 把 XML 文檔視為一種樹(shù)結(jié)構(gòu)。這種樹(shù)結(jié)構(gòu)被稱為<em>節(jié)點(diǎn)樹(shù)</em>。</p><p>可通過(guò)這棵樹(shù)訪問(wèn)所有節(jié)點(diǎn)??梢孕薷幕騽h除它們的內(nèi)容,也可以創(chuàng)建新的元素。</p><p>這顆節(jié)點(diǎn)樹(shù)展示了節(jié)點(diǎn)的集合,以及它們之間的聯(lián)系。這棵樹(shù)從根節(jié)點(diǎn)開(kāi)始,然后在樹(shù)的最低層級(jí)向文本節(jié)點(diǎn)長(zhǎng)出枝條:</p><p><img alt="DOM node tree"/></p><p>上面的圖片表示 XML 文件books.xml。</p><h3>父、子和同級(jí)節(jié)點(diǎn)</h3><p>節(jié)點(diǎn)樹(shù)中的節(jié)點(diǎn)彼此之間都有等級(jí)關(guān)系。</p><p>父、子和同級(jí)節(jié)點(diǎn)用于描述這種關(guān)系。父節(jié)點(diǎn)擁有子節(jié)點(diǎn),位于相同層級(jí)上的子節(jié)點(diǎn)稱為同級(jí)節(jié)點(diǎn)(兄弟或姐妹)。</p><ul><li><p>在節(jié)點(diǎn)樹(shù)中,頂端的節(jié)點(diǎn)成為根節(jié)點(diǎn)</p></li><li><p>根節(jié)點(diǎn)之外的每個(gè)節(jié)點(diǎn)都有一個(gè)父節(jié)點(diǎn)</p></li><li><p>節(jié)點(diǎn)可以有任何數(shù)量的子節(jié)點(diǎn)</p></li><li><p>葉子是沒(méi)有子節(jié)點(diǎn)的節(jié)點(diǎn)</p></li><li><p>同級(jí)節(jié)點(diǎn)是擁有相同父節(jié)點(diǎn)的節(jié)點(diǎn)</p></li></ul><p>下面的圖片展示出節(jié)點(diǎn)樹(shù)的一個(gè)部分,以及節(jié)點(diǎn)間的關(guān)系:</p><p><img alt="node tree"/></p><p>因?yàn)?XML 數(shù)據(jù)是按照樹(shù)的形式進(jìn)行構(gòu)造的,所以可以在不了解樹(shù)的確切結(jié)構(gòu)且不了解其中包含的數(shù)據(jù)類型的情況下,對(duì)其進(jìn)行遍歷。</p><p>您將在本教程稍后的章節(jié)學(xué)習(xí)更多有關(guān)遍歷節(jié)點(diǎn)樹(shù)的知識(shí)。</p><p>注釋:父節(jié)點(diǎn):Parent Node,子節(jié)點(diǎn):Children Node,同級(jí)節(jié)點(diǎn):Sibling Node。</p><h3>第一個(gè)子節(jié)點(diǎn) - 最后一個(gè)子節(jié)點(diǎn)</h3><p>請(qǐng)看下面的 XML 片段:</p><pre><bookstore> <book category="CHILDREN"> <title lang="en">Harry Potter J K. Rowling 2005 29.99

在上面的 XML 中, 元素是 <book> 元素的第一個(gè)子節(jié)點(diǎn),而 <price> 元素是 <book> 元素的最后一個(gè)子節(jié)點(diǎn)。</p><p>此外,<book> 元素是 <title>、<author>、<year> 以及 <price> 元素的父節(jié)點(diǎn)。</p><p><strong>解析 XML DOM</strong></p><h3>解析 XML</h3><p>所有現(xiàn)代瀏覽器都內(nèi)建了用于讀取和操作 XML 的 XML 解析器。</p><p>解析器把 XML 讀入內(nèi)存,并把它轉(zhuǎn)換為可被 JavaScript 訪問(wèn)的 XML DOM 對(duì)象。</p><p>微軟的 XML 解析器與其他瀏覽器中的解析器是有差異的。微軟的解析器支持對(duì) XML 文件和 XML 字符串(文本)的加載,而其他瀏覽器使用單獨(dú)的解析器。不過(guò),所有的解析器都含有遍歷 XML 樹(shù)、訪問(wèn)、插入及刪除節(jié)點(diǎn)的函數(shù)。</p><p>在本教程中,我們將為您講解如何創(chuàng)建可在 IE 及其他瀏覽器中運(yùn)行的腳本。</p><h3>通過(guò)微軟的 XML 解析器加載 XML</h3><p>微軟的 XML 解析器內(nèi)建于 Internet Explorer 5 及更高版本中。</p><p>下面的 JavaScript 片段把 XML 文檔 ("books.xml") 載入了解析器:</p><pre>xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); xmlDoc.async="false"; xmlDoc.load("books.xml");</pre><h4>代碼解釋:</h4><ul><li><p>第一行創(chuàng)建空的微軟 XML 文檔對(duì)象</p></li><li><p>第二行關(guān)閉異步加載,這樣可確保在文檔完整加載之前,解析器不會(huì)繼續(xù)執(zhí)行腳本</p></li><li><p>第三行告知解析器加載名為 "books.xml" 的文檔</p></li></ul><p>下面的 JavaScript 片段把名為 txt 的字符串載入解析器中:</p><pre>xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); xmlDoc.async="false"; xmlDoc.loadXML(txt);</pre><p>注釋:<em>loadXML()</em> 方法用于加載字符串(文本),而<em>load()</em> 用于加載文件。</p><h3>在 Firefox 及其他瀏覽器中的 XML 解析器</h3><p>下面的 JavaScript 片段把 XML 文檔 ("books.xml") 載入了解析器:</p><pre>xmlDoc=document.implementation.createDocument("","",null); xmlDoc.async="false"; xmlDoc.load("books.xml");</pre><h4>代碼解釋:</h4><ul><li><p>第一行創(chuàng)建空的 XML 文檔對(duì)象</p></li><li><p>第二行關(guān)閉異步加載,這樣可確保在文檔完整加載之前,解析器不會(huì)繼續(xù)執(zhí)行腳本</p></li><li><p>第三行告知解析器加載名為 "books.xml" 的文檔</p></li></ul><p>下面的 JavaScript 片段把名為 txt 的字符串載入解析器中:</p><pre>parser=new DOMParser(); xmlDoc=parser.parseFromString(txt,"text/xml");</pre><h4>代碼解釋:</h4><ul><li><p>第一行創(chuàng)建一個(gè)空的 XML 文檔對(duì)象</p></li><li><p>第二行告知解析器加載名為 txt 的字符串</p></li></ul><p>注釋:Internet Explorer 使用<em>loadXML()</em> 方法來(lái)解析 XML 字符串,而其他瀏覽器使用 <em>DOMParser</em> 對(duì)象。</p><h3>解析 XML 文件 - 一個(gè)跨瀏覽器的實(shí)例</h3><p>下面的例子把 XML 文檔 ("books.xml") 載入 XML 解析器:</p><pre><html> <body> <script type="text/javascript"> try //Internet Explorer { xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); } catch(e) { try //Firefox, Mozilla, Opera, etc. { xmlDoc=document.implementation.createDocument("","",null); } catch(e) {alert(e.message)} } try { xmlDoc.async=false; xmlDoc.load("books.xml"); document.write("xmlDoc is loaded, ready for use"); } catch(e) {alert(e.message)} </script> </body> </html></pre><h3>Error: Access Across Domains</h3><p>出于安全方面的原因,現(xiàn)代的瀏覽器不允許跨域的訪問(wèn)。</p><p>這意味著,網(wǎng)頁(yè)以及它試圖加載的 XML 文件,都必須位于相同的<a title="服務(wù)器" target="_blank" href="http://www.cdfuwuqi.com/">服務(wù)器</a>上。</p><p>W3School 的實(shí)例所打開(kāi)的 XML 文件位于 W3School 的域上。</p><p>假如你打算在自己的網(wǎng)頁(yè)上使用上面的例子,則必須把 XML 文件放到自己的服務(wù)器上。否則,xmlDoc.load() 將產(chǎn)生錯(cuò)誤 "Access is denied"。</p><h3>解析 XML 字符串 - 一個(gè)跨瀏覽器的實(shí)例</h3><p>下面的代碼加載并解析了一個(gè) XML 字符串:</p><pre><html> <body> <script type="text/javascript"> text="<bookstore>" text=text+"<book>"; text=text+"<title>Harry Potter"; text=text+"J K. Rowling"; text=text+"2005"; text=text+""; text=text+""; try //Internet Explorer { xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); xmlDoc.async="false"; xmlDoc.loadXML(text); } catch(e) { try //Firefox, Mozilla, Opera, etc. { parser=new DOMParser(); xmlDoc=parser.parseFromString(text,"text/xml"); } catch(e) {alert(e.message)} } document.write("xmlDoc is loaded, ready for use");

XML DOM 加載函數(shù)

加載函數(shù)

XML DOM 含有遍歷 XML 樹(shù)以及訪問(wèn)、插入、刪除節(jié)點(diǎn)的方法(函數(shù))。

然后,在訪問(wèn)并處理 XML 文檔之前,必須把它載入 XML DOM 對(duì)象。

上一節(jié)演示了如何加載 XML 文檔。為了避免因加載文檔而重復(fù)編寫(xiě)代碼,可以把代碼存儲(chǔ)在一個(gè)單獨(dú)的 JavaScript 文件中:

function loadXMLDoc(dname) 
{
try //Internet Explorer
  {
  xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
  }
catch(e)
  {
  try //Firefox, Mozilla, Opera, etc.
    {
    xmlDoc=document.implementation.createDocument("","",null);
    }
  catch(e) {alert(e.message)}
  }
try 
  {
  xmlDoc.async=false;
  xmlDoc.load(dname);
  return(xmlDoc);
  }
catch(e) {alert(e.message)}
return(null);
}

上面的函數(shù)存儲(chǔ)在名為 "loadxmldoc.js" 的文件中。

下面的例子在其 部分有一個(gè)指向 "loadxmldoc.js" 的鏈接,并使用 loadXMLDoc() 函數(shù)加載 XML 文檔 ("books.xml"):








XML DOM - 屬性和方法

編程接口

DOM 把 XML 模擬為一系列節(jié)點(diǎn)接口??赏ㄟ^(guò) JavaScript 或其他編程語(yǔ)言來(lái)訪問(wèn)節(jié)點(diǎn)。在本教程中,我們使用 JavaScript。

對(duì) DOM 的編程接口是通過(guò)一套標(biāo)準(zhǔn)的屬性和方法來(lái)定義的。

屬性經(jīng)常按照“某事物是什么”的方式來(lái)使用(例如節(jié)點(diǎn)名是 "book")。

方法經(jīng)常按照“對(duì)某事物做什么”的方式來(lái)使用(例如刪除 "book" 節(jié)點(diǎn))。

XML DOM 屬性

一些典型的 DOM 屬性:

  • x.nodeName - x 的名稱

  • x.nodeValue - x 的值

  • x.parentNode - x 的父節(jié)點(diǎn)

  • x.childNodes - x 的子節(jié)點(diǎn)

  • x.attributes - x 的屬性節(jié)點(diǎn)

注釋:在上面的列表中,x 是一個(gè)節(jié)點(diǎn)對(duì)象。

XML DOM 方法

  • x.getElementsByTagName(name) - 獲取帶有指定標(biāo)簽名稱的所有元素

  • x.appendChild(node) - 向 x 插入子節(jié)點(diǎn)

  • x.removeChild(node) - 從 x 刪除子節(jié)點(diǎn)

注釋:在上面的列表中,x 是一個(gè)節(jié)點(diǎn)對(duì)象。

實(shí)例

從 books.xml 中的 元素獲取文本的 JavaScript 代碼:</p><pre>txt=xmlDoc.getElementsByTagName("title")[0].childNodes[0].nodeValue</pre><p>在此語(yǔ)句執(zhí)行后,txt 保存的值是 "Everyday Italian"。</p><h4>解釋:</h4><ul><li><p><em>xmlDoc</em> - 由解析器創(chuàng)建的 XML DOM</p></li><li><p><em>getElementsByTagName("title")[0]</em> - 第一個(gè) <title> 元素</p></li><li><p><em>childNodes[0]</em> - <title> 元素的第一個(gè)子節(jié)點(diǎn) (文本節(jié)點(diǎn))</p></li><li><p><em>nodeValue</em> - 節(jié)點(diǎn)的值 (文本自身)</p></li></ul><p>在上面的例子中,getElementsByTagName 是方法,而 childNodes 和 nodeValue 是屬性。</p><h3>解析 XML 文件 - 跨瀏覽器實(shí)例</h3><p>下面的代碼片段使用 loadXMLDoc 函數(shù)把books.xml 載入 XML 解析器中,并顯示第一個(gè) book 的數(shù)據(jù):</p><pre>xmlDoc=loadXMLDoc("books.xml"); document.write(xmlDoc.getElementsByTagName("title") [0].childNodes[0].nodeValue); document.write("<br />"); document.write(xmlDoc.getElementsByTagName("author") [0].childNodes[0].nodeValue); document.write("<br />"); document.write(xmlDoc.getElementsByTagName("year") [0].childNodes[0].nodeValue);</pre><p>輸出:</p><pre>Harry Potter J K. Rowling 2005</pre><p>在上面的例子中,我們?yōu)槊總€(gè)文本節(jié)點(diǎn)使用 childNodes[0],即使每個(gè)元素只有一個(gè)文本節(jié)點(diǎn)。這是由于 getElementsByTagName() 方法總是會(huì)返回?cái)?shù)組。</p><h3>解析 XML 字符串 - 跨瀏覽器實(shí)例</h3><p>下面的代碼加載并解析一個(gè) XML 字符串:</p><p>下面的代碼片段使用 loadXMLString 函數(shù)把books.xml 載入 XML 解析器,并顯示第一個(gè) book 的數(shù)據(jù):</p><pre>text="<bookstore>" text=text+"<book>"; text=text+"<title>Harry Potter"; text=text+"J K. Rowling"; text=text+"2005"; text=text+""; text=text+""; xmlDoc=loadXMLString(text); document.write(xmlDoc.getElementsByTagName("title") [0].childNodes[0].nodeValue); document.write("
"); document.write(xmlDoc.getElementsByTagName("author") [0].childNodes[0].nodeValue); document.write("
"); document.write(xmlDoc.getElementsByTagName("year") [0].childNodes[0].nodeValue);

輸出:

Harry Potter
J K. Rowling
2005

訪問(wèn)節(jié)點(diǎn)

您可以通過(guò)三種方法來(lái)訪問(wèn)節(jié)點(diǎn):

  1. 通過(guò)使用 getElementsByTagName() 方法

  2. 通過(guò)循環(huán)(遍歷)節(jié)點(diǎn)樹(shù)

  3. 通過(guò)利用節(jié)點(diǎn)的關(guān)系在節(jié)點(diǎn)樹(shù)中導(dǎo)航

getElementsByTagName() 方法

getElementsByTagName() 返回?fù)碛兄付?biāo)簽名的所有元素。

語(yǔ)法

node.getElementsByTagName("tagname");

實(shí)例

下面的例子返回 x 元素下的所有 元素:</p><pre>x.getElementsByTagName("title");</pre><p>請(qǐng)注意,上面的例子僅返回 x 節(jié)點(diǎn)下的 <title> 元素。要返回 XML 文檔中的所有 <title> 元素,請(qǐng)使用:</p><pre>xmlDoc.getElementsByTagName("title");</pre><p>在這里,xmlDoc 就是文檔本身(文檔節(jié)點(diǎn))。</p><h3>DOM Node List</h3><p>getElementsByTagName() 方法返回節(jié)點(diǎn)列表 (node list)。節(jié)點(diǎn)列表是節(jié)點(diǎn)的數(shù)組。</p><p>下面的代碼通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中,然后在變量 x 中存儲(chǔ) <title> 節(jié)點(diǎn)的一個(gè)列表:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("title");</pre><p>可通過(guò)下標(biāo)訪問(wèn) x 中的 <title> 元素。要訪問(wèn)第三個(gè) <title>,您可以編寫(xiě):</p><pre>y=x[2];</pre><p>注釋:下標(biāo)以 0 起始。</p><p>在本教程中稍后的章節(jié),您將學(xué)到更多有關(guān) Node List 的知識(shí)。</p><h3>DOM Node List Length</h3><p>length 屬性定義節(jié)點(diǎn)列表的長(zhǎng)度(即節(jié)點(diǎn)的數(shù)目)。</p><p>您能夠通過(guò)使用 length 屬性來(lái)循環(huán)一個(gè)節(jié)點(diǎn)列表:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("title"); for (i=0;i<x.length;i++) { document.write(x[i].childNodes[0].nodeValue); document.write("<br />"); }</pre><h4>例子解釋:</h4><ol><li><p>使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc</p></li><li><p>取得所有 <title> 元素節(jié)點(diǎn)</p></li><li><p>輸出每個(gè) <title> 元素的文本節(jié)點(diǎn)的值</p></li></ol><h3>Node Type</h3><p>XML 文檔的 <em>documentElement</em> 屬性是根節(jié)點(diǎn)。</p><p>節(jié)點(diǎn)的 <em>nodeName</em> 屬性是節(jié)點(diǎn)的名稱。</p><p>節(jié)點(diǎn)的 <em>nodeType</em> 屬性是節(jié)點(diǎn)的類型。</p><p>您將在本教程的下一節(jié)中學(xué)習(xí)更多有關(guān)節(jié)點(diǎn)屬性的知識(shí)。</p><h3>遍歷節(jié)點(diǎn)</h3><p>下面的代碼循環(huán)根節(jié)點(diǎn)的子節(jié)點(diǎn),同時(shí)也是元素節(jié)點(diǎn):</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.documentElement.childNodes; for (i=0;i<x.length;i++) { if (x[i].nodeType==1) {//Process only element nodes (type 1) document.write(x[i].nodeName); document.write("<br />"); } }</pre><h4>例子解釋:</h4><ol><li><p>通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中</p></li><li><p>獲得根元素的子節(jié)點(diǎn)</p></li><li><p>檢查每個(gè)子節(jié)點(diǎn)的節(jié)點(diǎn)類型。如果節(jié)點(diǎn)類型是 "1",則是元素節(jié)點(diǎn)</p></li><li><p>如果是元素節(jié)點(diǎn),則輸出節(jié)點(diǎn)的名稱</p></li></ol><h3>利用節(jié)點(diǎn)的關(guān)系進(jìn)行導(dǎo)航</h3><p>下面的代碼通過(guò)利用節(jié)點(diǎn)的關(guān)系在節(jié)點(diǎn)樹(shù)中進(jìn)行導(dǎo)航:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("book")[0].childNodes; y=xmlDoc.getElementsByTagName("book")[0].firstChild; for (i=0;i<x.length;i++) { if (y.nodeType==1) {//Process only element nodes (type 1) document.write(y.nodeName + "<br />"); } y=y.nextSibling; }</pre><ol><li><p>通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中</p></li><li><p>獲得第一個(gè) book 元素的子節(jié)點(diǎn)</p></li><li><p>把 "y" 變量設(shè)置為第一個(gè) book 元素的第一個(gè)子節(jié)點(diǎn)</p></li><li><p>檢查每個(gè)子節(jié)點(diǎn)的節(jié)點(diǎn)類型,如果節(jié)點(diǎn)類型是 "1",則是元素節(jié)點(diǎn)</p></li><li><p>如果是元素節(jié)點(diǎn),則輸出該節(jié)點(diǎn)的名稱</p></li><li><p>把 "y" 變量設(shè)置為下一個(gè)同級(jí)節(jié)點(diǎn),并再次運(yùn)行循環(huán)</p></li></ol><p></p><h3>節(jié)點(diǎn)的屬性</h3><p>在 XML 文檔對(duì)象模型 (DOM) 中,每個(gè)節(jié)點(diǎn)都是一個(gè)<em>對(duì)象</em>。</p><p>對(duì)象擁有方法(功能)和屬性(關(guān)于對(duì)象的信息),并可通過(guò) JavaScript 進(jìn)行訪問(wèn)和操作。</p><p>三個(gè)重要的 XML DOM 節(jié)點(diǎn)屬性是:</p><ul><li><p>nodeName</p></li><li><p>nodeValue</p></li><li><p>nodeType</p></li></ul><h3>nodeName 屬性</h3><p>nodeName 屬性規(guī)定節(jié)點(diǎn)的名稱。</p><ul><li><p>nodeName 是只讀的</p></li><li><p>元素節(jié)點(diǎn)的 nodeName 與標(biāo)簽名相同</p></li><li><p>屬性節(jié)點(diǎn)的 nodeName 是屬性的名稱</p></li><li><p>文本節(jié)點(diǎn)的 nodeName 永遠(yuǎn)是 #text</p></li><li><p>文檔節(jié)點(diǎn)的 nodeName 永遠(yuǎn)是 #document</p></li></ul><h3>nodeValue 屬性</h3><p>nodeValue 屬性規(guī)定節(jié)點(diǎn)的值。</p><ul><li><p>元素節(jié)點(diǎn)的 nodeValue 是 undefined</p></li><li><p>文本節(jié)點(diǎn)的 nodeValue 是文本自身</p></li><li><p>屬性節(jié)點(diǎn)的 nodeValue 是屬性的值</p></li></ul><h3>例子 1:獲取元素的值</h3><p>下面的代碼檢索第一個(gè) <title> 元素的文本節(jié)點(diǎn)的值:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("title")[0].childNodes[0]; txt=x.nodeValue;</pre><p>結(jié)果:txt = "Everyday Italian"</p><h4>代碼解釋:</h4><ul><li><p>通過(guò)使用 loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中</p></li><li><p>獲取第一個(gè) <title> 元素節(jié)點(diǎn)的文本節(jié)點(diǎn)</p></li><li><p>把 txt 變量設(shè)置為文本節(jié)點(diǎn)的值</p></li></ul><h3>例子 2:更改元素的值</h3><p>下面的代碼更改第一個(gè) <title> 元素的文本節(jié)點(diǎn)的值:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("title")[0].childNodes[0]; x.nodeValue="Easy Cooking";</pre><h4>代碼解釋:</h4><ul><li><p>通過(guò)使用 loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中</p></li><li><p>獲取第一個(gè) <title> 元素節(jié)點(diǎn)的文本節(jié)點(diǎn)</p></li><li><p>把文本節(jié)點(diǎn)的值更改為 "Easy Cooking"</p></li></ul><h3>nodeType 屬性</h3><p>nodeType 屬性規(guī)定節(jié)點(diǎn)的類型。</p><p>nodeType 是只讀的。</p><h4>最重要的節(jié)點(diǎn)類型是:</h4><table class="dataintable"><tbody><trl><th>元素類型</th><th>節(jié)點(diǎn)類型</th></tr><tr><td>元素</td><td>1</td></tr><tr><td>屬性</td><td>2</td></tr><tr><td>文本</td><td>3</td></tr><tr><td>注釋</td><td>8</td></tr><tr><td>文檔</td><td>9</td></tr></tbody></table><p></p><h3>DOM Node List</h3><p>當(dāng)使用諸如 childNodes 或 getElementsByTagName() 屬性或方法時(shí),會(huì)返回 NodeList 對(duì)象。</p><p>NodeList 對(duì)象表示節(jié)點(diǎn)的列表,以 XML 中的相同順序。</p><p>使用從 0 開(kāi)始的下標(biāo)來(lái)訪問(wèn)節(jié)點(diǎn)列表中的節(jié)點(diǎn)。</p><p>下面的圖像表示 "books.xml" 中 <title> 元素的節(jié)點(diǎn)列表:</p><p><img alt="DOM node list"/></p><p>下面的代碼片段通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中,并返回 "books.xml" 中 title 元素的一個(gè)節(jié)點(diǎn)列表:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("title");</pre><p>以上語(yǔ)句執(zhí)行之后,x 成為一個(gè) NodeList 對(duì)象。</p><p>下面的代碼片段從節(jié)點(diǎn)列表 x 中的第一個(gè) <title> 元素中返回文本:</p><pre>txt=x[0].childNodes[0].nodeValue;</pre><p>在以上語(yǔ)句執(zhí)行之后,txt = "Everyday Italian"。</p><h3>Node List Length</h3><p>NodeList 對(duì)象會(huì)保持自身的更新。如果刪除或添加了元素,列表會(huì)自動(dòng)更新。</p><p>節(jié)點(diǎn)列表的 length 屬性是列表中節(jié)點(diǎn)的數(shù)量。</p><p>下面的代碼片段通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc,并返回 "books.xml" 中 <title> 元素的數(shù)量:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName('title').length;</pre><p>在上面的語(yǔ)句執(zhí)行之后,x = 4。</p><p>節(jié)點(diǎn)列表的長(zhǎng)度可用于循環(huán)列表中所有的元素。</p><p>下面的代碼片段使用 length 屬性來(lái)遍歷 <title> 元素的列表:</p><pre>xmlDoc=loadXMLDoc("books.xml"); //the x variable will hold a node list x=xmlDoc.getElementsByTagName('title'); for (i=0;i<x.length;i++) { document.write(x[i].childNodes[0].nodeValue); document.write("<br />"); }</pre><p>輸出:</p><pre>Harry Potter Everyday Italian XQuery Kick Start Learning XML</pre><h4>例子解釋:</h4><ul><li><p>通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc</p></li><li><p>設(shè)置保存所有 title 元素的節(jié)點(diǎn)列表的 x 變量</p></li><li><p>從所有 <title> 元素的文本節(jié)點(diǎn)輸出值</p></li></ul><h3>DOM Attribute List (Named Node Map)</h3><p>元素節(jié)點(diǎn)的 attributes 屬性返回屬性節(jié)點(diǎn)的列表。</p><p>這被稱為 Named Node Map,除了方法和屬性上的一些差別以外,它與節(jié)點(diǎn)列表相似。</p><p>屬性列表會(huì)保持自身的更新。如果刪除或添加屬性,這個(gè)列表會(huì)自動(dòng)更新。</p><p>下面的代碼片段通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中,并從 "books.xml" 中的第一個(gè) <book> 元素返回屬性節(jié)點(diǎn)的一個(gè)列表:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName('book')[0].attributes;</pre><p>以上代碼執(zhí)行之后,x.length 等于屬性的數(shù)量,可使用 x.getNamedItem() 返回屬性節(jié)點(diǎn)。</p><p>下面的代碼片段一個(gè) book 的 "category" 屬性的值,以及其屬性的數(shù)量:</p><pre>xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.getElementsByTagName("book")[0].attributes; document.write(x.getNamedItem("category").nodeValue); document.write("<br />" + x.length);</pre><p>輸出:</p><pre>children 1</pre><h4>例子解釋:</h4><ul><li><p>通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中</p></li><li><p>把 x 變量設(shè)置為第一個(gè) <book> 元素的所有屬性的一個(gè)列表</p></li><li><p>從 "category" 屬性輸出其值</p></li><li><p>輸出屬性列表的長(zhǎng)度</p></li></ul><p></p><h2>XML DOM 遍歷節(jié)點(diǎn)樹(shù)</h2><p></p><p><strong>遍歷 (Traverse) 意味著在節(jié)點(diǎn)樹(shù)中進(jìn)行循環(huán)或移動(dòng)。</strong></p><h3>實(shí)例</h3><p>下面的例子使用 XML 文件books.xml。</p><p>函數(shù)loadXMLString(),位于外部 JavaScript 中,用于加載 XML 文件。</p><ul><li><p>遍歷一棵節(jié)點(diǎn)樹(shù)</p></li><li><p>循環(huán) <book> 元素的所有子節(jié)點(diǎn)。</p></li></ul><h3>遍歷節(jié)點(diǎn)樹(shù)</h3><p>您經(jīng)常需要循環(huán) XML 文檔,比如:當(dāng)你需要提取每個(gè)元素的值時(shí)。</p><p>這個(gè)過(guò)程叫作“遍歷節(jié)點(diǎn)樹(shù)”。</p><p>下面的例子循環(huán) <book> 的所有子節(jié)點(diǎn),并顯示它們的名稱和值:</p><pre><html> <head> <script type="text/javascript" src="loadxmlstring.js"></script> </head> <body> <script type="text/javascript"> text="<book>"; text=text+"<title>Harry Potter"; text=text+"J K. Rowling"; text=text+"2005"; text=text+""; xmlDoc=loadXMLString(text); // documentElement always represents the root node x=xmlDoc.documentElement.childNodes; for (i=0;i"); }

輸出:

title: Harry Potter
author: J K. Rowling
year: 2005

例子解釋:

  • loadXMLString() 把 XML 字符串載入 xmlDoc 中

  • 獲取根元素的子節(jié)點(diǎn)

  • 輸出每個(gè)子節(jié)點(diǎn)的名稱,以及文本節(jié)點(diǎn)的節(jié)點(diǎn)值

定位 DOM 節(jié)點(diǎn)

通過(guò)節(jié)點(diǎn)間的關(guān)系訪問(wèn)節(jié)點(diǎn)樹(shù)中的節(jié)點(diǎn),通常稱為定位節(jié)點(diǎn) ("navigating nodes")。

在 XML DOM 中,節(jié)點(diǎn)的關(guān)系被定義為節(jié)點(diǎn)的屬性:

  • parentNode

  • childNodes

  • firstChild

  • lastChild

  • nextSibling

  • previousSibling

下面的圖像展示了books.xml 中節(jié)點(diǎn)樹(shù)的一個(gè)部分,并說(shuō)明了節(jié)點(diǎn)之間的關(guān)系:

DOM node tree

DOM - 父節(jié)點(diǎn)

所有的節(jié)點(diǎn)都僅有一個(gè)父節(jié)點(diǎn)。下面的代碼定位到 的父節(jié)點(diǎn):

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.getElementsByTagName("book")[0];
document.write(x.parentNode.nodeName);

例子解釋:

  • 通過(guò)使用loadXMLDoc() 把 "books.xml" 載入到 xmlDoc 中

  • 獲取第一個(gè) 元素

  • 輸出 "x" 的父節(jié)點(diǎn)的節(jié)點(diǎn)名

TIY

避免空的文本節(jié)點(diǎn)

Firefox,以及其他一些瀏覽器,把空的空白或換行當(dāng)作文本節(jié)點(diǎn),而 IE 不會(huì)這么做。

這會(huì)在使用下列屬性使產(chǎn)生一個(gè)問(wèn)題:firstChild、lastChild、nextSibling、previousSibling。

為了避免定位到空的文本節(jié)點(diǎn)(元素節(jié)點(diǎn)之間的空格和換行符號(hào)),我們使用一個(gè)函數(shù)來(lái)檢查節(jié)點(diǎn)的類型:

function get_nextSibling(n)
{
y=n.nextSibling;
while (y.nodeType!=1)
  {
  y=y.nextSibling;
  }
return y;
}

有了上面的函數(shù),我們就可以使用 get_nextSibling(node) 來(lái)代替 node.nextSibling 屬性。

代碼解釋:

元素節(jié)點(diǎn)的類型是 1。如果同級(jí)節(jié)點(diǎn)不是元素節(jié)點(diǎn),就移動(dòng)到下一個(gè)節(jié)點(diǎn),直到找到元素節(jié)點(diǎn)為止。通過(guò)這個(gè)辦法,在 IE 和 Firefox 中,都可以得到相同的結(jié)果。

獲取第一個(gè)元素

下面的代碼顯示第一個(gè) 的第一個(gè)元素節(jié)點(diǎn):










輸出:

title

例子解釋:

  • 通過(guò)使用loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中

  • 在第一個(gè) 上使用 get_firstChild 函數(shù),來(lái)獲取元素節(jié)點(diǎn)中的第一個(gè)子節(jié)點(diǎn)

  • 輸出第一個(gè)子節(jié)點(diǎn)(屬于元素節(jié)點(diǎn))的節(jié)點(diǎn)名

以上就是XML DOM是什么意思,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


網(wǎng)站名稱:XMLDOM是什么意思
網(wǎng)頁(yè)路徑:http://weahome.cn/article/jsogei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部