首頁 >後端開發 >XML/RSS教程 >使用JavaScript存取XML數據

使用JavaScript存取XML數據

黄舟
黄舟原創
2017-03-03 17:11:581572瀏覽

在網頁瀏覽器軟體中,可以Internet Explorer (IE)現在是一種標準的軟體。可以看到,運行不同版本的Windows作業系統(和很多其他的作業系統)的每一台機器幾乎都使用IE。微軟已經透過ActiveX控制項將IE的功能包含在執行成熟的xml處理技術中。

在本篇文章中,我們將講述如何在IE中使用ActiveX功能來存取並解析XML文檔,由此允許網路衝浪者操縱它們。

上網
我們以標準的順序文件開始,如表A所示。此文件包含簡單的順序資料以提供網路衝浪者瀏覽之用。不只為了顯示這些數據,我們還提供了一個簡單的使用者介面,網路上沖浪都可以使用這個介面來瀏覽XML文件。

表A: order.xml

<?xml version="1.0" ?>
<Order>
  <Account>9900234</Account>
  <Item id="1">
    <SKU>1234</SKU>
    <PRicePer>5.95</PricePer>
    <Quantity>100</Quantity>
    <Subtotal>595.00</Subtotal>
    <Description>Super Widget Clamp</Description>
  </Item>
  <Item id="2">
    <SKU>6234</SKU>
    <PricePer>22.00</PricePer>
    <Quantity>10</Quantity>
    <Subtotal>220.00</Subtotal>
    <Description>Mighty Foobar Flange</Description>
  </Item>
  <Item id="3">
    <SKU>9982</SKU>
    <PricePer>2.50</PricePer>
    <Quantity>1000</Quantity>
    <Subtotal>2500.00</Subtotal>
    <Description>Deluxe Doohickie</Description>
  </Item>
  <Item id="4">
    <SKU>3256</SKU>
    <PricePer>389.00</PricePer>
    <Quantity>1</Quantity>
    <Subtotal>389.00</Subtotal>
    <Description>Muckalucket Bucket</Description>
  </Item>
  <NumberItems>1111</NumberItems>
  <Total>3704.00</Total>
  <OrderDate>07/07/2002</OrderDate>
  <OrderNumber>8876</OrderNumber>
</Order>

我們使用一個網絡表單以存取這一XML文檔,這一表單將顯示SKU,價格,數量,各部分的小計,以及順序中的每一個選項的描述。我們的表單還包含向前和向後瀏覽選項的按鈕。

網頁的構成
網頁的重要部分是在於表單,我們將使用一個表格以易讀的方式在螢幕上顯示。下面是顯示HTML表的程式碼片段:

<form>
  <table border="0">
    <tr><td>SKU</td><td><input type="text" name="SKU"></td></tr>
    <tr><td>Price</td><td><input type="text" name="Price"></td></tr>
    <tr><td>Quantity</td><td><input type="text" name="Quantity"></td></tr>
    <tr><td>Total</td><td><input type="text" name="Total"></td></tr>
    <tr><td>Description</td><td><input type="text"
 name="Description"></td></tr>
  </table>
  <input type="button" value="  <<  " onClick="getDataPrev();">  <input
 type="button" value="  >>  " onClick="getDataNext();">
  </form>

請注意到,我們在表的下麵包含了兩個按鈕,即透過getDataNext() 和getDataPrev()函數來瀏覽前一個和後一個的記錄,這也是我們所要討論的問題。

腳本
其實,我們網頁的實質部分不是在於表單,而是在於控製表單的腳本。在我們的腳本中包括四個部分。首先,我們透過載入XML文件而初始化網頁。第二部分是導航到下一個記錄。第三步是導航到前一個記錄。第四部分是從XML文件中提取單一的值。表B顯示了我們的網頁的全部內容。

表B: jsxml.html

<html>
  <head>
    <script language="javaScript">
<!--
    vari = -1;
    varorderDoc = new ActiveXObject("MSXML2.DOMDocument.3.0");
    orderDoc.load("order.xml");
    var items = orderDoc.selectNodes("/Order/Item");
        
    function getNode(doc, xpath) {
      varretval = "";
      var value = doc.selectSingleNode(xpath);
      if (value) retval = value.text;
      return retval;
    }
    
    function getDataNext() {
      i++;
      if (i > items.length - 1) i = 0;
      document.forms[0].SKU.value = getNode(orderDoc, "/Order/Item[" +
 i + "]/SKU");
      document.forms[0].Price.value = getNode(orderDoc, "/Order/Item["
 + i + "]/PricePer");
      document.forms[0].Quantity.value = getNode(orderDoc,
 "/Order/Item[" + i + "]/Quantity");
      document.forms[0].Total.value = getNode(orderDoc, "/Order/Item["
 + i + "]/Subtotal");
      document.forms[0].Description.value = getNode(orderDoc,
 "/Order/Item[" + i + "]/Description");
    }
    
    function getDataPrev() {
      i--;
      if (i < 0) i = items.length - 1;
      
      document.forms[0].SKU.value = getNode(orderDoc, "/Order/Item[" +
 i + "]/SKU");
      document.forms[0].Price.value = getNode(orderDoc, "/Order/Item["
 + i + "]/PricePer");
      document.forms[0].Quantity.value = getNode(orderDoc,
 "/Order/Item[" + i + "]/Quantity");
      document.forms[0].Total.value = getNode(orderDoc, "/Order/Item["
+ i + "]/Subtotal");
      document.forms[0].Description.value = getNode(orderDoc,
 "/Order/Item[" + i + "]/Description");
    }
    
// -->
    </script>
  </head>
  <body onload="getDataNext()">
  <h2>XML Order Database</h2>
  <form>
  <table border="0">
    <tr><td>SKU</td><td><input type="text" name="SKU"></td></tr>
    <tr><td>Price</td><td><input type="text" name="Price"></td></tr>
    <tr><td>Quantity</td><td><input type="text"
 name="Quantity"></td></tr>
    <tr><td>Total</td><td><input type="text" name="Total"></td></tr>
    <tr><td>Description</td><td><input type="text"
 name="Description"></td></tr>
  </table>
  <input type="button" value="  <<  " onClick="getDataPrev();">  <input
 type="button" value="  >>  " onClick="getDataNext();">
  </form>  
  </body>
</html>

執行
這一網頁將會傳入並執行腳本的初始化。你一定確保order.xml文件與jsxml.html在相同的相同的路徑上。

初始化部分將一個新的ActiveX物件範例為MSXML2.DOMDocument.3.0物件類型,然後腳本傳入order.xml文件到記憶體中,並選擇所有的/Order/Item節點。我們使用/Order/Item節點以識別文件已經包含的選項。

文件中的6c04bd5ca3fcae76e30b72ad730ca86d標準有一個onLoad屬性,這個屬性能夠使得網頁呼叫getDataNext()而初始化。此功能可用於從XML文件中取得下一個值並顯示在表單中。我們使用一個簡單的索引來存取特定的選項。

向前(>>)和向後(<<)按鈕都使用相同的機制。首先響應onClick事件而呼叫getDataNext() 或getDataPrev(),這兩個函數使用了邏輯方法以避免文檔以外的範圍存取我們的記錄。

 以上就是使用JavaScript存取XML資料的內容,更多相關內容請關注PHP中文網(www.php.cn)!


#
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn