隨筆 - 6  文章 - 129  trackbacks - 0
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(14)

          隨筆檔案(6)

          文章分類(467)

          文章檔案(423)

          相冊

          收藏夾(18)

          JAVA

          搜索

          •  

          積分與排名

          • 積分 - 827218
          • 排名 - 49

          最新評論

          閱讀排行榜

          評論排行榜

          出處:http://www.webjx.com/htmldata/2007-06-30/1183208042.html

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

          實(shí)例

          解析XML文件 - 跨瀏覽器的實(shí)例

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

          <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字符串 - 跨瀏覽器的實(shí)例

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

          <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>

          解析一個(gè)XML文檔

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

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

          微軟的XML解析器

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

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

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

          JavaScript:
          var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
          VBScript:
          set xmlDoc=CreateObject("Microsoft.XMLDOM")
          ASP:
          set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")

          下面的代碼段可向微軟的XML解析器載入一個(gè)已有的XML文檔("note.xml"):

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

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

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

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

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

          JavaScript:
          var xmlDoc=document.implementation.createDocument("ns","root",null);

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

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

          var xmlDoc=document.implementation.createDocument("","",null);
          xmlDoc.load("note.xml");

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

          解析某個(gè)XML文件 - 跨瀏覽器的實(shí)例

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

          <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>

          輸出:

          W3Schools Internal Note
          To: Tove
          From: Jani
          Message: Don't forget me this weekend!

          重要的注釋

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

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

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

          解析一個(gè)XML字符串 - 跨瀏覽器的實(shí)例

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

          <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>

          輸出:

          Text of first child element: Tove
          Text of second child element: Jani

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




          posted on 2007-09-29 16:27 Ke 閱讀(3089) 評論(0)  編輯  收藏 所屬分類: xml

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 大姚县| 常宁市| 淳安县| 临夏市| 洪洞县| 阜宁县| 鄂温| 宁阳县| 新疆| 吉木萨尔县| 谢通门县| 巴林左旗| 清远市| 邹平县| 徐闻县| 罗江县| 清镇市| 临猗县| 威海市| 辽中县| 东光县| 若羌县| 奎屯市| 日土县| 清远市| 塔河县| 平陆县| 民勤县| 甘洛县| 大冶市| 靖宇县| 连山| 齐河县| 抚宁县| 清新县| 横山县| 磐安县| 海南省| 红原县| 庄浪县| 海晏县|