麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > XML > 正文

XML入門教程:XML 解析器

2024-09-05 20:54:18
字體:
供稿:網(wǎng)友

如需讀取、更新、創(chuàng)建或者操作某個XML文檔,則需要XML解析器。

實例

解析XML文件 - 跨瀏覽器的實例

本例是一個跨瀏覽器的實例,把某個XML文檔("note.xml")載入XML解析器。

以下為引用的內(nèi)容:
<html>
<body>
<script type="text/vbscript">
set xmlDoc=CreateObject("Microsoft.XMLDOM")
xmlDoc.async="false"
xmlDoc.load("/example/xmle/xmle_xml_note.xml")
document.write("<h1>Traversing the XML nodes</h1>")
for each x in xmlDoc.documentElement.childNodes
document.write("<b>" & x.nodename & "</b>")
document.write(": ")
document.write(x.text)
document.write("<br><br>")
next
</script>
</body>
</html>

解析XML字符串 - 跨瀏覽器的實例

本例是一個跨瀏覽器的實例,展示如何載入并解析某個XML字符串。

以下為引用的內(nèi)容:
<html>
<body>
<script type="text/javascript">
var xmlDoc = new ActiveXObject("Microsoft.XMLDOM")
xmlDoc.async="false"
xmlDoc.load("/example/xmle/xmle_xml_note.xml")
document.write
("The first XML element in the file contains: ")
document.write
(xmlDoc.documentElement.childNodes.item(0).text)
</script>
</body>
</html>

解析一個XML文檔

如需操作某個XML文檔,您需要XML解析器。解析器會將文檔載入電腦的內(nèi)存中。一旦文檔被載入,可使用DOM對其數(shù)據(jù)進(jìn)行操作。DOM把XML作為一顆樹來處理。

微軟的XML解析器與Mozilla瀏覽器中使用的解析器是有差異的。在本教程中,我們會為您展示如何創(chuàng)建可工作于IE和Mozilla瀏覽器中的跨瀏覽器腳本。

微軟的XML解析器

微軟的XML解析器是存在于IE 5.0或更高版本中的COM組件。一旦你安裝了IE,就可使用腳本來利用解析器了。

微軟的XML解析器支持所有必要的功能,來遍歷節(jié)點樹,訪問節(jié)點以及它們的屬性值,插入并刪除節(jié)點,并將節(jié)點數(shù)轉(zhuǎn)換回XML。

如需創(chuàng)建微軟XML解析器的一個實例,請使用下面的代碼:

以下為引用的內(nèi)容:

JavaScript:
var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
VBScript:
set xmlDoc=CreateObject("Microsoft.XMLDOM")
ASP:
set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")
下面的代碼段可向微軟的XML解析器載入一個已有的XML文檔("note.xml"):

var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async="false";
xmlDoc.load("note.xml");

上面的腳本的第一行創(chuàng)建了XML解析器的一個實例。第二行關(guān)閉了同步載入,這樣可以確保在文檔被完全載入前解析器不會繼續(xù)執(zhí)行。第三行會告知解析器載入名為"note.xml"的XML的文檔。

Mozilla、Firefox以及Opera中的XML解析器

Mozilla瀏覽器的XML解析器支持所有必要的功能,來遍歷節(jié)點樹,訪問節(jié)點以及它們的屬性值,插入并刪除節(jié)點,并將節(jié)點樹轉(zhuǎn)換回XML。

如需創(chuàng)建Mozilla瀏覽器的XML解析器的一個實例,請使用下面的代碼:

以下為引用的內(nèi)容:
JavaScript:
var xmlDoc=document.implementation.createDocument("ns","root",null);

第一個參數(shù),ns,定義用于XML文檔的命名空間(namespace)。第二個參數(shù),root,是XML文件中的XML根元素。第三個參數(shù),null,一般總是null,這是由于目前還沒有用到這個參數(shù)。

下面的代碼段可向Mozilla瀏覽器的XML解析器載入一個已有的XML文檔("note.xml"):

以下為引用的內(nèi)容:
var xmlDoc=document.implementation.createDocument("","",null);
xmlDoc.load("note.xml");

上面的腳本的第一行創(chuàng)建了XML解析器的一個實例。第二行會告知解析器載入名為"note.xml"的XML的文檔。

解析某個XML文件 - 跨瀏覽器的實例

下面的例子是一個跨瀏覽器的實例,向XML解析器載入了某個已有的XML文檔("note.xml"):

以下為引用的內(nèi)容:
<html>
<head>
<script type="text/javascript">
var xmlDoc;
function loadXML()
{
// 用于 IE 的代碼:
if (window.ActiveXObject)
{
xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async=false;
xmlDoc.load("note.xml");
getmessage();
}
// 用于 Mozilla, Firefox, Opera, 等瀏覽器的代碼:
else if (document.implementation &&
document.implementation.createDocument)
{
xmlDoc=document.implementation.createDocument("","",null);
xmlDoc.load("note.xml");
xmlDoc.onload=getmessage;
}
else
{
alert('Your browser cannot handle this script');
}
}
function getmessage()
{
document.getElementById("to").innerHTML=
xmlDoc.getElementsByTagName("to")[0].childNodes[0].nodeValue;
document.getElementById("from").innerHTML=
xmlDoc.getElementsByTagName("from")[0].childNodes[0].nodeValue;
document.getElementById("message").innerHTML=
xmlDoc.getElementsByTagName("body")[0].childNodes[0].nodeValue;
}
</script>
</head>
<body onload="loadXML()">
<h1>W3Schools Internal Note</h1>
<p><b>To:</b> <span id="to"></span><br />
<b>From:</b> <span id="from"></span><br />
<b>Message:</b> <span id="message"></span>
</p>
</body>
</html>

輸出:

以下為引用的內(nèi)容:
W3Schools Internal Note
To: Tove
From: Jani
Message: Don't forget me this weekend!

重要的注釋

如需從某個XML元素(比如<from>Jani</from>)中提取文本(比如Jani),請使用下面的語法:

getElementsByTagName("from")[0].childNodes[0].nodeValue

重要事項:getElementsByTagName會返回一個節(jié)點數(shù)組。此數(shù)組含有XML文檔中擁有指定名稱的所有元素。在這例子中,只有一個"from"元素,但是仍然需要設(shè)定數(shù)組的下標(biāo)( [0] )。

解析一個XML字符串 - 跨瀏覽器的實例

下面的代碼是一個跨瀏覽器的實例,向我們展示了如何加載和解析某個XML字符串:

以下為引用的內(nèi)容:
<html>
<body>
<script type="text/javascript">
var text="<note>";
text=text "<to>Tove</to>";
text=text "<from>Jani</from>";
text=text "<heading>Reminder</heading>";
text=text "<body>Don't forget me this weekend!</body>";
text=text "</note>";
// 用于 IE 的代碼:
if (window.ActiveXObject)
{
var doc=new ActiveXObject("Microsoft.XMLDOM");
doc.async="false";
doc.loadXML(text);
}
// 用于 Mozilla, Firefox, Opera, 等瀏覽器的代碼:
else
{
var parser=new DOMParser();
var doc=parser.parseFromString(text,"text/xml");
}
// documentElement 提交根元素:
var x=doc.documentElement;
document.write("Text of first child element: ");
document.write(x.childNodes[0].childNodes[0].nodeValue);
document.write("<br />");
document.write("Text of second child element: ");
document.write(x.childNodes[1].childNodes[0].nodeValue);
</script>
</body>
</html>

輸出:

以下為引用的內(nèi)容:
Text of first child element: Tove
Text of second child element: Jani

注釋:Internet Explorer使用loadXML()方法解析XML字符串,而Mozilla瀏覽器使用DOMParser對象。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑人一区二区三区四区五区 | 久草在线资源福利站 | 亚洲视屏| 国产精品久久久久影院老司 | 国产精品久久久久久久久岛 | 精国产品一区二区三区 | 免费国产wwwwwww网站 | 久久影城 | 日韩黄在线 | 欧美一级免费视频 | 草逼一区 | 久久综合婷婷香五月 | 男人的天堂视频网站 | 亚洲二区三区在线 | 毛片免费视频观看 | 狠狠干天天操 | 国产女厕一区二区三区在线视 | av在线更新 | 91精品国 | 久久久久久久免费看 | 久久久久久久久久久影视 | 久久99精品国产99久久6男男 | 国产精品呻吟 | 中文字幕电影免费播放 | 午夜国产精品成人 | 色吧综合网| 狠狠操天天射 | 国产91精品亚洲精品日韩已满 | 日韩字幕在线 | 精品久久久久久久久久久久久 | 久在线观看福利视频69 | 欧美日韩网站在线观看 | 成人做爽爽爽爽免费国产软件 | 91豆奶 | 伊人久久国产精品 | 久久影院yy6080 | 久久成人国产精品 | 欧美巨根| 精品国产乱码久久久久久丨区2区 | 成人精品久久久 | 国产一级aa大片毛片 |