麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發(fā)設計 > 正文

使用ActiveX功能查找并顯示XML數(shù)據(jù)

2019-11-18 12:46:57
字體:
供稿:網(wǎng)友

  在網(wǎng)絡瀏覽器軟件中,可以Internet EXPlorer (IE)現(xiàn)在是一種標準的軟件。可以看到,運行不同版本的Windows操作系統(tǒng)(和很多其他的操作系統(tǒng))的每一臺機器幾乎都使用IE。微軟已經(jīng)通過ActiveX控件將IE的功能包含在執(zhí)行成熟的xml處理技術中。
  
  在本篇文章中,我們將講述如何在IE中使用ActiveX功能來訪問并解析XML文檔,由此答應網(wǎng)絡沖浪者操縱它們。
  
  網(wǎng)上沖浪
  
  我們以一個標準的順序文檔而開始,如表A所示。這一文檔包含簡單的順序數(shù)據(jù)以提供網(wǎng)絡沖浪者瀏覽之用。不僅僅為了顯示這些數(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)絡表單以訪問這一XML文檔,這一表單將顯示SKU,價格,數(shù)量,各部分的小計,以及順序中的每一選項的描述。我們的表單還包含向前和向后瀏覽選項的按鈕。
  
  網(wǎng)頁的構成
  
  網(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ù)來瀏覽前一個和后一個的記錄,這也是我們所要討論的問題。
  
  腳本
  
  其實,我們網(wǎng)頁的實質(zhì)部分不是在于表單,而是在于控制表單的腳本。在我們的腳本中包括四個部分。首先,我們通過載入XML文檔而初始化網(wǎng)頁。第二部分是導航到下一個記錄。第三步是導航到前一個記錄。第四部分是從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>
  
  運行
  
  這一網(wǎng)頁將傳入并運行腳本的初始化。你一定確保order.xml文檔與jsxml.html在相同的相同的路徑上。
  
  初始化部分將一個新的ActiveX對象例示為MSXML2.DOMDocument.3.0對象類型,然后腳本傳入order.xml文檔到內(nèi)存中,并選擇所有的/Order/Item節(jié)點。我們使用/Order/Item節(jié)點以識別文檔已經(jīng)包含的選項。
  
  文檔中的<body>標準有一個onLoad屬性,這一屬性能夠使得網(wǎng)頁調(diào)用getDataNext()而初始化。這一功能可用于從XML文檔中獲得下一個值并顯示在表單中。我們使用一個簡單的索引來訪問特定的選項。
  
  向前(>>)和向后(<<)按鈕都使用相同的機制。首先響應onClick事件而調(diào)用getDataNext() 或者getDataPrev(),這兩個函數(shù)使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 圆产精品久久久久久久久久久 | 国产一级淫片在线观看 | 亚洲婷婷日日综合婷婷噜噜噜 | 成人宗合网 | 国产亚洲自拍一区 | 九九热精| 成人一区二区三区在线 | 欧美一级黄色免费看 | 黄色片免费在线播放 | 亚洲一级片在线观看 | 一级黄色国产视频 | 91久久夜色精品国产网站 | 色妞欧美| 欧美一级免费视频 | 亚洲黑人在线观看 | av电影在线观看免费 | aa久久| 国产精品亚洲欧美一级在线 | 国产精品视频免费网站 | 欧美精品免费一区二区三区 | 精品一区免费 | 九九视频精品在线 | 久久久精品综合 | 精品呦女 | 欧美成人一区二区三区 | 久久草在线观看视频 | 欧洲伊人网 | 色诱亚洲精品久久久久久 | 5xx免费看| 神马久久精品综合 | 在线播放一区二区三区 | 免费永久看羞羞片网站入口 | 美女扒开腿让男生桶爽网站 | 青青草国产在线视频 | 羞羞网站在线观看入口免费 | 久久撸视频| 欧美日韩1区2区3区 黄片毛片一级 | 日韩1区| 欧美一级成人一区二区三区 | chinese18 xxxx videos | 久成人 |