在網頁瀏覽器軟體中,可以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 id="XML-nbsp-Order-nbsp-Database">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節點以識別文件已經包含的選項。
文件中的
標準有一個onLoad屬性,這個屬性能夠使得網頁呼叫getDataNext()而初始化。此功能可用於從XML文件中取得下一個值並顯示在表單中。我們使用一個簡單的索引來存取特定的選項。向前(>>)和向後(
以上就是使用JavaScript存取XML資料的內容,更多相關內容請關注PHP中文網(www.php.cn)!

RSS是一種基於XML的格式,用於發布經常更新的內容。 1.RSSfeed通過XML結構化組織信息,包括標題、鏈接、描述等。 2.創建RSSfeed需按照XML結構編寫,添加元數據如語言和發布日期。 3.高級用法可包含多媒體文件和分類信息。 4.調試時使用XML驗證工具,確保必需元素存在且編碼正確。 5.優化RSSfeed可通過分頁、緩存和保持結構簡潔來實現。通過理解和應用這些知識,可以有效管理和分發內容。

RSS是一種基於XML的格式,用於發布和訂閱內容。 RSS文件的XML結構包括根元素、元素和多個元素,每個代表一個內容條目。通過XML解析器讀取和解析RSS文件,用戶可以訂閱並獲取最新內容。

XML在RSS中具有結構化數據、可擴展性、跨平台兼容性和解析驗證的優勢。 1)結構化數據確保內容的一致性和可靠性;2)可擴展性允許添加自定義標籤以適應內容需求;3)跨平台兼容性使其在不同設備上無縫工作;4)解析和驗證工具確保Feed的質量和完整性。

RSS在XML中的實現方式是通過結構化的XML格式來組織內容。 1)RSS使用XML作為數據交換格式,包含頻道信息和項目列表等元素。 2)生成RSS文件需按規範組織內容,發佈到服務器供訂閱。 3)RSS文件可通過閱讀器或插件訂閱,實現內容自動更新。

RSS的高級功能包括內容命名空間、擴展模塊和條件訂閱。 1)內容命名空間擴展RSS功能,2)擴展模塊如DublinCore或iTunes添加元數據,3)條件訂閱根據特定條件篩選條目。這些功能通過添加XML元素和屬性實現,提升信息獲取效率。

RSSFEEDSUSEXMLTOSSTRUCTURECONTUPDATE.1)XMLPROVIDEDIDESAHIERARCHICALSTRUCTUREFFORDATA.2)THEELEMENTDEFINESTHEEFEED'SIDENTITYANDCONTAINS ELEMENT.3)ELEMENTEMERPREPRESERPRESENTERPRESENTIVIDIVIVELPIECTUALPIECES.4)RSSSSSSSSSSSISEXTEXTENSIBLERECTICERSINCREECTINCERINCTICENT.5)

RSS和XML是用於網絡內容管理的工具。 RSS用於發布和訂閱內容,XML用於存儲和傳輸數據。它們的工作原理包括內容髮布、訂閱和更新推送。使用示例包括RSS發布博客文章和XML存儲書籍信息。

RSS文檔是基於XML的結構化文件,用於發布和訂閱頻繁更新的內容。它的主要作用包括:1)自動化內容更新,2)內容聚合,3)提高瀏覽效率。通過RSSfeed,用戶可以訂閱並及時獲取來自不同來源的最新信息。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

WebStorm Mac版
好用的JavaScript開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能