青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

使用JavaScript訪問XML數據

在網絡瀏覽器軟件中,可以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(),這兩個函數使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。

posted on 2010-10-20 11:28 wrh 閱讀(196) 評論(0)  編輯 收藏 引用

導航

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統計

常用鏈接

留言簿(19)

隨筆檔案

文章檔案

收藏夾

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            精品999日本| 一区二区三区日韩欧美精品| 久久高清福利视频| 欧美亚洲三区| 久久本道综合色狠狠五月| 亚洲免费视频观看| 午夜日韩视频| 另类天堂视频在线观看| 老司机精品导航| 欧美巨乳在线| 国产精品国色综合久久| 国产精品大片| 精品不卡一区| 亚洲色图自拍| 久久久国产精品亚洲一区 | 国产亚洲第一区| 亚洲高清不卡| 在线亚洲激情| 久久久久看片| 亚洲精品国产精品国自产观看浪潮| 欧美ab在线视频| 亚洲每日在线| 欧美一区二区视频在线观看2020| 久久久亚洲人| 欧美视频一区二区三区在线观看| 国产性做久久久久久| 亚洲精品欧洲| 久久久久国色av免费观看性色| 亚洲国产精品免费| 欧美一区二区日韩| 欧美精品一区二区三区久久久竹菊 | 99精品国产热久久91蜜凸| 午夜在线观看免费一区| 欧美国产日韩亚洲一区| 国产精品一区二区三区乱码| 亚洲国产精品va在线看黑人动漫 | 午夜在线一区| 欧美精品福利视频| 在线成人国产| 玖玖综合伊人| 亚洲女人天堂av| 欧美.日韩.国产.一区.二区| 夜夜嗨一区二区| 免费观看一区| 伊人久久婷婷色综合98网| 午夜国产不卡在线观看视频| 亚洲啪啪91| 欧美阿v一级看视频| 国产在线乱码一区二区三区| 亚洲午夜精品一区二区| 亚洲国产精品小视频| 久久久亚洲欧洲日产国码αv| 国产精品视频一区二区三区| 在线一区日本视频| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美亚洲一区二区在线观看| 亚洲精品永久免费精品| 欧美激情国产精品| 亚洲精品网址在线观看| 亚洲电影天堂av| 美女主播视频一区| 一区二区三区在线观看视频| 久久精品中文| 久久黄色级2电影| 狠狠色伊人亚洲综合网站色| 久久久亚洲午夜电影| 久久久www成人免费精品| 黄色精品免费| 久久综合图片| 久久亚洲风情| 亚洲精品视频在线播放| 亚洲日本欧美在线| 欧美国产视频日韩| aa国产精品| 亚洲免费久久| 国产精品私拍pans大尺度在线 | 亚洲欧美日韩国产另类专区| 国产精品白丝jk黑袜喷水| 亚洲欧美日韩在线一区| 亚洲一区中文| 激情成人在线视频| 亚洲国产精品电影| 欧美黄色网络| 欧美亚洲免费电影| 久久久久久亚洲综合影院红桃| 亚洲国产黄色| 亚洲午夜高清视频| 狠狠色狠狠色综合日日91app| 欧美国产日韩一区二区三区| 欧美人在线视频| 欧美一区91| 欧美韩日一区二区| 小黄鸭精品密入口导航| 韩国美女久久| 久久高清福利视频| 久久久久**毛片大全| 日韩午夜在线播放| 亚洲综合第一页| 91久久中文| 亚洲一区二区毛片| 在线看国产一区| 一区二区欧美国产| 亚洲成人直播| 亚洲特色特黄| 亚洲精品免费一区二区三区| 午夜日韩av| 亚洲一区二区在线看| 麻豆9191精品国产| 久久精品国产在热久久| 欧美日韩在线免费| 欧美激情a∨在线视频播放| 国产欧美一区二区精品仙草咪| 亚洲国产经典视频| 精品999在线观看| 亚洲综合电影| 一区二区三区四区蜜桃| 久久性色av| 久久久久在线| 国产精品系列在线播放| 亚洲人成人99网站| 亚洲国产一区二区三区高清 | 亚洲午夜在线视频| 欧美多人爱爱视频网站| 久久久久久9| 国产乱码精品一区二区三区五月婷| 欧美ab在线视频| 激情成人综合网| 亚洲欧美综合一区| 午夜精品电影| 欧美日韩亚洲一区二区三区在线 | 狠狠综合久久av一区二区老牛| 一本色道久久综合亚洲精品高清| 亚洲国产精品综合| 久久久久9999亚洲精品| 欧美一二三视频| 国产精品久久久久免费a∨大胸| 亚洲国产精品一区在线观看不卡 | 猛男gaygay欧美视频| 久久一区二区三区四区五区| 国产亚洲激情| 亚洲欧美资源在线| 欧美在线1区| 国产女同一区二区| 欧美一级艳片视频免费观看| 欧美亚洲一区二区在线| 国产精品老牛| 亚洲自拍偷拍麻豆| 欧美一级在线视频| 国产在线视频欧美一区二区三区| 欧美在线观看视频在线| 小黄鸭精品密入口导航| 欧美国产成人在线| 激情欧美日韩一区| 久久综合给合| 欧美国产综合视频| 日韩视频在线一区| 欧美午夜电影网| 亚洲欧美伊人| 免费日本视频一区| 99精品欧美一区二区蜜桃免费| 欧美日韩国产一区精品一区| 宅男在线国产精品| 久久久精品午夜少妇| 亚洲级视频在线观看免费1级| 欧美日韩国产免费观看| 亚洲女同在线| 欧美va天堂va视频va在线| 亚洲精品一区二区三区婷婷月 | 亚洲第一毛片| 一本一本久久| 国产日本欧美一区二区三区在线| 久久精品1区| 亚洲伦理自拍| 久久精品夜夜夜夜久久| 亚洲国产清纯| 国产精品免费看久久久香蕉| 久久精品在线| 中文av字幕一区| 久久一区中文字幕| 一本色道久久综合狠狠躁篇怎么玩 | 久久久亚洲一区| 日韩午夜在线观看视频| 国产视频久久| 欧美日韩国产一区精品一区| 欧美在线观看你懂的| 亚洲毛片视频| 欧美成人亚洲| 欧美一级免费视频| 99re6这里只有精品| 国产一区二区三区日韩| 欧美日韩亚洲一区二区三区在线 | 久久久噜噜噜久久狠狠50岁| 一区二区国产日产| 亚洲风情亚aⅴ在线发布| 国产精品久久久久婷婷| 欧美日本一道本| 久久综合亚州| 久久激情婷婷| 亚洲欧美欧美一区二区三区| 91久久精品一区二区三区|