欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用javascript訪問XML數(shù)據(jù)的實(shí)例

 更新時間:2006年12月27日 00:00:00   作者:  
在網(wǎng)絡(luò)瀏覽器軟件中,可以Internet Explorer (IE)現(xiàn)在是一種標(biāo)準(zhǔn)的軟件。可以看到,運(yùn)行不同版本的Windows操作系統(tǒng)(和很多其他的操作系統(tǒng))的每一臺機(jī)器幾乎都使用IE。微軟已經(jīng)通過ActiveX控件將IE的功能包含在執(zhí)行成熟的XML處理技術(shù)中。

在本篇文章中,我們將講述如何在IE中使用ActiveX功能來訪問并解析XML文檔,由此允許網(wǎng)絡(luò)沖浪者操縱它們。

網(wǎng)上沖浪
我們以一個標(biāo)準(zhǔn)的順序文檔而開始,如表A所示。這一文檔包含簡單的順序數(shù)據(jù)以提供網(wǎng)絡(luò)沖浪者瀏覽之用。不僅僅為了顯示這些數(shù)據(jù),我們還提供了一個簡單的用戶界面,網(wǎng)上沖浪都可以使用這一界面來瀏覽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>

我們使用一個網(wǎng)絡(luò)表單以訪問這一XML文檔,這一表單將顯示SKU,價格,數(shù)量,各部分的小計(jì),以及順序中的每一選項(xiàng)的描述。我們的表單還包含向前和向后瀏覽選項(xiàng)的按鈕。

網(wǎng)頁的構(gòu)成
網(wǎng)頁的重要部分是在于表單,我們將使用一個表以易讀的方式在屏幕上顯示。下面是顯示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()函數(shù)來瀏覽前一個和后一個的記錄,這也是我們所要討論的問題。

腳本
其實(shí),我們網(wǎng)頁的實(shí)質(zhì)部分不是在于表單,而是在于控制表單的腳本。在我們的腳本中包括四個部分。首先,我們通過載入XML文檔而初始化網(wǎng)頁。第二部分是導(dǎo)航到下一個記錄。第三步是導(dǎo)航到前一個記錄。第四部分是從XML文檔中提取單一的值。表B顯示了我們的網(wǎng)頁的全部內(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ùn)行腳本的初始化。你一定確保order.xml文檔與jsxml.html在相同的相同的路徑上。

初始化部分將一個新的ActiveX對象例示為MSXML2.DOMDocument.3.0對象類型,然后腳本傳入order.xml文檔到內(nèi)存中,并選擇所有的/Order/Item節(jié)點(diǎn)。我們使用/Order/Item節(jié)點(diǎn)以識別文檔已經(jīng)包含的選項(xiàng)。

文檔中的<body>標(biāo)準(zhǔn)有一個onLoad屬性,這一屬性能夠使得網(wǎng)頁調(diào)用getDataNext()而初始化。這一功能可用于從XML文檔中獲得下一個值并顯示在表單中。我們使用一個簡單的索引來訪問特定的選項(xiàng)。

向前(>>)和向后(<<)按鈕都使用相同的機(jī)制。首先響應(yīng)onClick事件而調(diào)用getDataNext() 或者getDataPrev(),這兩個函數(shù)使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。

相關(guān)文章

  • JavaScript 處理Iframe自適應(yīng)高度(同或不同域名下)

    JavaScript 處理Iframe自適應(yīng)高度(同或不同域名下)

    Iframe自適應(yīng)高度一直都備受關(guān)注,接下來為大家介紹下同域名下Iframe自適應(yīng)高度的處理以及跨域時Iframe高度自適應(yīng),感興趣的朋友可以參考下哈
    2013-03-03
  • ES6字符串的擴(kuò)展實(shí)例

    ES6字符串的擴(kuò)展實(shí)例

    這篇文章主要介紹了ES6字符串的擴(kuò)展實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • js父窗口關(guān)閉時子窗口隨之關(guān)閉完美解決方案

    js父窗口關(guān)閉時子窗口隨之關(guān)閉完美解決方案

    admin注銷的時候,或者main.html關(guān)閉的時候,如何讓打開的所有新窗口一起關(guān)閉,下面有個不錯的解決方案,大家可以參考下
    2014-04-04
  • JavaScript EasyPager 分頁函數(shù)

    JavaScript EasyPager 分頁函數(shù)

    好久不寫js,手都有點(diǎn)生了。寫個小東西熱手。
    2011-05-05
  • javascript仿京東導(dǎo)航左側(cè)分類導(dǎo)航下拉菜單效果

    javascript仿京東導(dǎo)航左側(cè)分類導(dǎo)航下拉菜單效果

    這篇文章主要為大家詳細(xì)介紹了javascript仿京東導(dǎo)航左側(cè)分類導(dǎo)航下拉菜單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • JavaScript函數(shù)節(jié)流的兩種寫法

    JavaScript函數(shù)節(jié)流的兩種寫法

    本文主要介紹了JavaScript函數(shù)節(jié)流的兩種寫法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • 微信小程序?qū)崿F(xiàn)城市列表選擇

    微信小程序?qū)崿F(xiàn)城市列表選擇

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)城市列表選擇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • TypeScript遍歷Array的方法(for,forEach,every)

    TypeScript遍歷Array的方法(for,forEach,every)

    本文主要介紹了TypeScript遍歷Array的方法(for,forEach,every),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • JS打開圖片另存為對話框?qū)崿F(xiàn)代碼

    JS打開圖片另存為對話框?qū)崿F(xiàn)代碼

    使用JS打開圖片另存為對話框一直都是網(wǎng)頁應(yīng)用中不可缺少的一部分,本人有些好奇,于是搜集整理了一些實(shí)現(xiàn)代碼,不知道符不符合大眾的口味,在此班門弄斧了,需要的朋友可以了解下
    2012-12-12
  • 微信小程序加載機(jī)制及運(yùn)行機(jī)制圖解

    微信小程序加載機(jī)制及運(yùn)行機(jī)制圖解

    這篇文章主要介紹了微信小程序加載機(jī)制及運(yùn)行機(jī)制圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11

最新評論