|
在網(wǎng)絡(luò)瀏覽器軟件中,可以Internet Explorer (IE)現(xiàn)在是一種標(biāo)準(zhǔn)的軟件?梢钥吹剑\(yùn)行不同版本的Windows操作系統(tǒng)(和很多其他的操作系統(tǒng))的每一臺(tái)機(jī)器幾乎都使用IE。微軟已經(jīng)通過(guò)ActiveX控件將IE的功能包含在執(zhí)行成熟的XML處理技術(shù)中。 在本篇文章中,我們將講述如何在IE中使用ActiveX功能來(lái)訪問(wèn)并解析XML文檔,由此允許網(wǎng)絡(luò)沖浪者操縱它們。 網(wǎng)上沖浪 我們以一個(gè)標(biāo)準(zhǔn)的順序文檔而開(kāi)始,如表A所示。這一文檔包含簡(jiǎn)單的順序數(shù)據(jù)以提供網(wǎng)絡(luò)沖浪者瀏覽之用。不僅僅為了顯示這些數(shù)據(jù),我們還提供了一個(gè)簡(jiǎn)單的用戶界面,網(wǎng)上沖浪都可以使用這一界面來(lái)瀏覽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> 我們使用一個(gè)網(wǎng)絡(luò)表單以訪問(wèn)這一XML文檔,這一表單將顯示SKU,價(jià)格,數(shù)量,各部分的小計(jì),以及順序中的每一選項(xiàng)的描述。我們的表單還包含向前和向后瀏覽選項(xiàng)的按鈕。 網(wǎng)頁(yè)的構(gòu)成 網(wǎng)頁(yè)的重要部分是在于表單,我們將使用一個(gè)表以易讀的方式在屏幕上顯示。下面是顯示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> 請(qǐng)注意到,我們?cè)诒淼南旅姘藘蓚(gè)按鈕,即通過(guò)getDataNext() 和getDataPrev()函數(shù)來(lái)瀏覽前一個(gè)和后一個(gè)的記錄,這也是我們所要討論的問(wèn)題。 腳本 其實(shí),我們網(wǎng)頁(yè)的實(shí)質(zhì)部分不是在于表單,而是在于控制表單的腳本。在我們的腳本中包括四個(gè)部分。首先,我們通過(guò)載入XML文檔而初始化網(wǎng)頁(yè)。第二部分是導(dǎo)航到下一個(gè)記錄。第三步是導(dǎo)航到前一個(gè)記錄。第四部分是從XML文檔中提取單一的值。表B顯示了我們的網(wǎng)頁(yè)的全部?jī)?nèi)容。 表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> 運(yùn)行 這一網(wǎng)頁(yè)將傳入并運(yùn)行腳本的初始化。你一定確保order.xml文檔與jsxml.html在相同的相同的路徑上。 初始化部分將一個(gè)新的ActiveX對(duì)象例示為MSXML2.DOMDocument.3.0對(duì)象類型,然后腳本傳入order.xml文檔到內(nèi)存中,并選擇所有的/Order/Item節(jié)點(diǎn)。我們使用/Order/Item節(jié)點(diǎn)以識(shí)別文檔已經(jīng)包含的選項(xiàng)。 文檔中的<body>標(biāo)準(zhǔn)有一個(gè)onLoad屬性,這一屬性能夠使得網(wǎng)頁(yè)調(diào)用getDataNext()而初始化。這一功能可用于從XML文檔中獲得下一個(gè)值并顯示在表單中。我們使用一個(gè)簡(jiǎn)單的索引來(lái)訪問(wèn)特定的選項(xiàng)。 向前(>>)和向后(<<)按鈕都使用相同的機(jī)制。首先響應(yīng)onClick事件而調(diào)用getDataNext() 或者getDataPrev(),這兩個(gè)函數(shù)使用了邏輯方法以避免文檔以外的范圍訪問(wèn)我們的記錄。 ----------------------------------------------------------------
本文作者Brian Schaffner是富士通咨詢公司的副主任。他為富士通的技術(shù)咨詢公司提供架構(gòu)、設(shè)計(jì)和開(kāi)發(fā)支持。
|