XML教程之XML 解析器_Xml教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:解讀ASP生成WML文件源代碼樣本
      必須注意得是,該文件必須保存為.asp為后綴。另外IIS或者其它服務器端必須設置可執行教本程序。 %@ Language=VBScript % % Responst.ContentType=text/vnd.wap.wml %?xml version=1.0? E wml PUBLIC -//WAPFORUM//DTD WML 1.1//EN http://www.

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

      實例

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

      本例是一個跨瀏覽器的實例,把某個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字符串 - 跨瀏覽器的實例

      本例是一個跨瀏覽器的實例,展示如何載入并解析某個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>

      解析一個XML文檔

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

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

      微軟的XML解析器

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

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

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

      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");

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

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

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

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

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

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

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

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

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

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

      下面的例子是一個跨瀏覽器的實例,向XML解析器載入了某個已有的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>T</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
      T Tove
      From: Jani
      Message: Don't forget me this weekend!

      重要的注釋

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

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

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

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

      下面的代碼是一個跨瀏覽器的實例,向我們展示了如何加載和解析某個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對象。
       

       

      分享:WML Script語法基礎
      WML Script是屬于無限應用協議WAP應用層的一部分,使用它可以向WML卡片組和卡片中添加客戶端的處理邏輯,目前最新的版本是1.1版。WML Script1.1是在歐洲計算機制造商協議會制定的ECMAScript腳本語言的基礎上,經過修改和優化而指定的。它能夠更好的支持諸如

      來源:模板無憂//所屬分類:Xml教程/更新時間:2010-02-26
      相關Xml教程