Ajax對xml信息的接收和處理操作實例分析

本文實例講述了ajax對xml信息的接收和處理操作。分享給大家供大家參考,具體如下:

ajax負責(zé)請求和接收xml信息,dom負責(zé)處理xml信息。

dom:

php中,dom是php 與 xml(html)之間溝通的橋梁
javascript中,dom是javascript 與 html(xml)之間溝通的橋梁

這里寫圖片描述

xml需要從服務(wù)器端返回到客戶端被javascript處理
ajax負責(zé)請求xml,dom(javascript)負責(zé)處理xml信息
ajax+javascript實現(xiàn)對xml的接收處理,可以方便我們后期實現(xiàn)一個靜態(tài)網(wǎng)站(html+css+javascript)實現(xiàn)對各個接口數(shù)據(jù)的處理。

自定義的xml文件

09.xml

<?xml version="1.0" encoding="utf-8"?>
<weather>
  <city>
    <name>北京</name>
    <temp>23-31度</temp>
    <wind>東風(fēng)</wind>
  </city>
  <city>
    <name>上海</name>
    <temp>25-32度</temp>
    <wind>東南風(fēng)</wind>
  </city>
  <city>
    <name>深圳</name>
    <temp>29-35度</temp>
    <wind>西南風(fēng)</wind>
  </city>
</weather>

ajax對xml信息的接收和處理處理代碼

<!doctype html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
  <title></title>
<script type="text/javascript">
  function f1(){
    //ajax請求xml信息
    //javascript的dom技術(shù)處理xml
    var xhr = new xmlhttprequest();
    xhr.onreadystatechange = function(){
      if(xhr.readystate == 4){
        //alert(xhr.responsexml);//object document 其是xml根節(jié)點的父節(jié)點對象
        var xmldom = xhr.responsexml;
        //console.log(xmldom.firstchild);//<weather>
        var citys = xmldom.getelementsbytagname('city');
        //console.log(citys);// htmlcollection[city, city, city]
        /*
        citys[1];//第二個city的元素節(jié)點對象
        for(var k in citys[1]){//k代表元素節(jié)點對象的成員名稱
          console.log(k);
          //有輸出這樣一個成員方法:getelementsbytagname
          //結(jié)論:document對象和普通元素對象都有g(shù)etelementsbytagname()方法
        }
        */
        var s = "";
        for(var i=0; i<citys.length; i++){
          var name = citys[i].getelementsbytagname('name')[0].firstchild.nodevalue;
          var temp = citys[i].getelementsbytagname('temp')[0].firstchild.nodevalue;
          var wind = citys[i].getelementsbytagname('wind')[0].firstchild.nodevalue;
          s += "城市:" + name + "--溫度:" + temp + "--風(fēng)向:" + wind + "<br />";
        }
        document.getelementbyid('result').innerhtml = s;
      }
    }
    xhr.open('get','./09.xml');
    xhr.send(null);
  }
</script>
</head>
<body>
  <h2>利用ajax+javascript實現(xiàn)對xml的接收和處理</h2>
  <input type="button" value="觸發(fā)" onclick="f1()" />
  <div id="result"></div>
</body>
</html>

運行結(jié)果

這里寫圖片描述

希望本文所述對大家ajax程序設(shè)計有所幫助。

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频