Ajax对xml信息的接收和处理操作实例分析
本文实例讲述了Ajax对xml信息的接收和处理操作。分享给大家供大家参考,具体如下:
Ajax负责请求和接收xml信息,DOM负责处理xml信息。
DOM:
php中,DOM是php 与 xml(html)之间沟通的桥梁
JavaScript中,DOM是JavaScript 与 html(xml)之间沟通的桥梁
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[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 + "--风向:" + 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="触发" onclick="f1()" /> <div id="result"></div> </body> </html>
运行结果
更多关于ajax相关内容感兴趣的读者可查看本站专题:《jquery中Ajax用法总结》、《JavaScript中ajax操作技巧总结》、《PHP+ajax技巧与应用小结》及《asp.net ajax技巧总结专题》
希望本文所述对大家ajax程序设计有所帮助。
您可能感兴趣的文章
阅读排行
本栏相关
- 01-11layui的checbox在Ajax局部刷新下的设置方
- 01-11ajax请求后台得到json数据后动态生成树
- 01-11ajax获得json对象数组 循环输出数据的
- 01-11解决ajax请求后台,有时收不到返回值的
- 01-11详谈ajax返回数据成功 却进入error的方
- 01-11解决AJAX返回状态200没有调用success的问
- 01-11快速解决ajax返回值给外部函数的问题
- 01-11Ajax实现动态显示并操作表信息的方法
- 01-11ajax实现从后台拿数据显示在HTML前端的
- 01-11ajax动态查询数据库数据并显示在前台
随机阅读
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-10C#中split用法实例总结
- 04-02jquery与jsp,用jquery
- 01-11ajax实现页面的局部加载
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10SublimeText编译C开发环境设置
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文