• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • 使用JavaScript訪問XML數據

    發表于:2007-06-21來源:作者:點擊數: 標簽:
    在網絡瀏覽器軟件中,可以Internet Explorer (IE)現在是一種標準的軟件??梢钥吹?,運行不同版本的 Windows 操作系統(和很多其他的操作系統)的每一臺機器幾乎都使用IE。微軟已經通過ActiveX控件將IE的功能包含在執行成熟的XML處理技術中。 在本篇文章中,我

       

    在網絡瀏覽器軟件中,可以Internet Explorer (IE)現在是一種標準的軟件??梢钥吹?,運行不同版本的Windows操作系統(和很多其他的操作系統)的每一臺機器幾乎都使用IE。微軟已經通過ActiveX控件將IE的功能包含在執行成熟的XML處理技術中。

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

    網上沖浪
    我們以一個標準的順序文檔而開始,如表A所示。這一文檔包含簡單的順序數據以提供網絡沖浪者瀏覽之用。不僅僅為了顯示這些數據,我們還提供了一個簡單的用戶界面,網上沖浪都可以使用這一界面來瀏覽XML文檔。

    表A: order.xml
    <?xml version="1.0" ?>
    <Order>
      <Aclearcase/" target="_blank" >ccount>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(),這兩個函數使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。


    ----------------------------------------------------------------

    本文作者Brian Schaffner是富士通咨詢公司的副主任。他為富士通的技術咨詢公司提供架構、設計和開發支持。

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>