在網絡浏覽器軟件中,可以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節點以識別文檔已經包含的選項。
文檔中的<body>標准有一個onLoad屬性,這一屬性能夠使得網頁調用getDataNext()而初始化。這一功能可用於從XML文檔中獲得下一個值並顯示在表單中。我們使用一個簡單的索引來訪問特定的選項。
向前(>>)和向後(<<)按鈕都使用相同的機制。首先響應onClick事件而調用getDataNext() 或者getDataPrev(),這兩個函數使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。
----------------------------------------------------------------
本文作者Brian Schaffner是富士通咨詢公司的副主任。他為富士通的技術咨詢公司提供架構、設計和開發支持。