• <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>

            使用JavaScript訪問XML數(shù)據(jù)

            在網(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,價(jià)格,數(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ù)使用了邏輯方法以避免文檔以外的范圍訪問我們的記錄。

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


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            導(dǎo)航

            <2012年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計(jì)

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产亚洲精品美女久久久| 婷婷综合久久狠狠色99h| 最新久久免费视频| 亚洲精品无码久久千人斩| 国产一久久香蕉国产线看观看 | 韩国三级大全久久网站| 久久久久人妻精品一区三寸蜜桃| 噜噜噜色噜噜噜久久| 久久综合九色综合97_久久久| 亚洲国产香蕉人人爽成AV片久久| 精品免费久久久久久久| 无码国内精品久久人妻麻豆按摩| 久久久久亚洲AV无码永不| 久久久久亚洲AV成人网人人网站| 久久亚洲精品无码AV红樱桃| 日本久久中文字幕| 亚洲国产精品久久久久久| 亚洲国产精品高清久久久| 久久久久久一区国产精品| 色偷偷888欧美精品久久久| 久久亚洲国产成人精品性色| 久久亚洲精品无码观看不卡| AV狠狠色丁香婷婷综合久久| 亚洲中文字幕久久精品无码APP| 久久精品亚洲男人的天堂| 国产午夜福利精品久久2021| 伊人久久大香线蕉av不变影院| 久久免费国产精品| 精品国产综合区久久久久久 | 久久精品无码一区二区app| 国产99久久精品一区二区| 午夜精品久久久久久毛片| 亚洲av伊人久久综合密臀性色| 欧美亚洲国产精品久久| 久久精品极品盛宴观看| 亚洲精品无码久久毛片| 国产精品久久久久久久人人看| 久久一区二区免费播放| yy6080久久| 久久久久久综合一区中文字幕 | 国产麻豆精品久久一二三|