咔叽游戏

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 189|回复: 0

[AJAX相关] Ajax对xml信息的接收和处理操作实例分析

[复制链接]
  • TA的每日心情
    无聊
    2019-5-27 08:20
  • 签到天数: 4 天

    [LV.2]圆转纯熟

    发表于 2019-10-18 12:40:31 | 显示全部楼层 |阅读模式
    本文实例讲述了Ajax对xml信息的接收和处理操作。分享给大家供大家参考,具体如下:
    Ajax负责请求和接收xml信息,DOM负责处理xml信息。
    DOM:
    php中,DOM是php 与 xml(html)之间沟通的桥梁
    JavaScript中,DOM是JavaScript 与 html(xml)之间沟通的桥梁
    Ajax对xml信息的接收和处理操作实例分析-1.png

    xml需要从服务器端返回到客户端被JavaScript处理
    Ajax负责请求xml,DOM(JavaScript)负责处理xml信息
    Ajax+JavaScript实现对xml的接收处理,可以方便我们后期实现一个静态网站(html+css+JavaScript)实现对各个接口数据的处理。
    自定义的xml文件
    09.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <weather>
      <city>
        <name>北京</name>
        <temp>23-31度</temp>
        <wind>东风</wind>
      </city>
      <city>
        <name>上海</name>
        <temp>25-32度</temp>
        <wind>东南风</wind>
      </city>
      <city>
        <name>深圳</name>
        <temp>29-35度</temp>
        <wind>西南风</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技术处理xml
        var xhr = new XMLHttpRequest();
        xhr.onreadystatechange = function(){
          if(xhr.readyState == 4){
            //alert(xhr.responseXML);//object Document 其是xml根节点的父节点对象
            var xmldom = xhr.responseXML;
            //console.log(xmldom.firstChild);//<weather>
            var citys = xmldom.getElementsByTagName('city');
            //console.log(citys);// HTMLCollection[city, city, city]
            /*
            citys[1];//第二个city的元素节点对象
            for(var k in citys[1]){//k代表元素节点对象的成员名称
              console.log(k);
              //有输出这样一个成员方法:getElementsByTagName
              //结论:document对象和普通元素对象都有getElementsByTagName()方法
            }
            */
            var s = "";
            for(var i=0; i<citys.length; i++){
              var name = citys.getElementsByTagName('name')[0].firstChild.nodeValue;
              var temp = citys.getElementsByTagName('temp')[0].firstChild.nodeValue;
              var wind = citys.getElementsByTagName('wind')[0].firstChild.nodeValue;
              s += "城市:" + name + "--温度:" + temp + "--风向:" + wind + "<br />";
            }
            document.getElementById('result').innerHTML = s;
          }
        }
        xhr.open('get','./09.xml');
        xhr.send(null);
      }
    </script>
    </head>
    <body>
      <h2>利用Ajax+JavaScript实现对xml的接收和处理</h2>
      <input type="button" value="触发"  />
      <div id="result"></div>
    </body>
    </html>

    运行结果
    Ajax对xml信息的接收和处理操作实例分析-2.png

    更多关于ajax相关内容感兴趣的读者可查看本站专题:《jquery中Ajax用法总结》、《JavaScript中ajax操作技巧总结》、《PHP+ajax技巧与应用小结》及《asp.net ajax技巧总结专题》
    希望本文所述对大家ajax程序设计有所帮助。

    QQ|免责声明|小黑屋|手机版|Archiver|咔叽游戏

    GMT+8, 2024-3-29 20:49

    Powered by Discuz! X3.4

    © 2001-2023 Discuz! Team.

    快速回复 返回顶部 返回列表