ajax 保存xmldoc对象,ajax遍历xml文档的方法

本文实例讲述了ajax遍历xml文档的方法。分享给大家供大家参考。具体分析如下:

XMLHttpRequest对象提供了两个可以用来访问服务器响应的属性。第一个属性responseText将响应提供为一个串,第二个属性 responseXML将响应提供为一个XML对象。一些简单的用例就很适合按简单文本来获取响应,如将响应显示在警告框中,或者响应只是指示成功还是失 败的词

前面中的例子是从XMLHttpRequest对象获取服务器响应,并使用XMLHttpRequest对象的responseText属性将响应获取为文本。

这次我们来使用XMLHttpRequest对象的responseXML属性,将结果获取为XML文档.这样一来,我们就可以使用W3C DOM方法来遍历XML文档。(前面文章或多或少讲过些DOM,在此不重复)

OK,下面来看例子.

首先还是一段XML文档代码(parseXML.xml)如下:

parseXML.xml如下:

Minnesota

Iowa

North Dakota

Texas

Oklahoma

Louisiana

New York

North Carolina

Massachusetts

California

Oregon

Nevada

MyJsp.jsp如下:

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

My JSP 'MyJsp.jsp' starting page

var flg=false;

var requestType = "";

//得到XMLHttpRequest对象

function newXMLHttpRequest() {

var xmlreq = false;

if (window.XMLHttpRequest) {

xmlreq = new XMLHttpRequest();

} else if (window.ActiveXObject) {

try {

xmlreq = new ActiveXObject("Msxml2.XMLHTTP");

} catch (e1) {

try {

xmlreq = new ActiveXObject("Microsoft.XMLHTTP");

} catch (e2) {}

}

}

return xmlreq;

}

function startRequest(requestedList){

requestType=requestedList;

flg=newXMLHttpRequest();

//当XMLHttpRequest对象在请求过程中间状态改变的时候

//回来调用handleStateChange方法

flg.onreadystatechange = handleStateChange;

flg.open("GET", "parseXML.xml", true);

flg.send(null);

}

//处理函数

function handleStateChange(){

if(flg.readyState==4){

if(flg.status==200){

if(requestType=="north"){

listNorthStates();

}else if(requestType=="all"){

listAllStates();

}if(requestType=="south"){

listSouthStates();

}

}

}

}

//用于显示NorthStates方法

function listNorthStates(){

var xmlDoc=flg.responseXML;

var northNode=xmlDoc.getElementsByTagName("north")[0];

var northStates=northNode.getElementsByTagName("state");

outputList("North States",northStates);

}

//用于显示SouthStates方法

function listSouthStates(){

var xmlDoc=flg.responseXML;

var SouthNode=xmlDoc.getElementsByTagName("south")[0];

var SouthStates=SouthNode.getElementsByTagName("state");

outputList("South States",SouthStates);

}

//用于显示AllStates方法

function listAllStates(){

var xmlDoc=flg.responseXML;

var allStates=xmlDoc.getElementsByTagName("state");

outputList("All States in Document", allStates);

}

//输出元素并显示于提示框中

function outputList(title,states){

var out=title;

var currState=null;

for(var i=0;i

currState=states;

out=out+"\n-"+currState.childNodes[0].nodeValue;

}

alert(out);

}

οnclick="startRequest('all');"/>

οnclick="startRequest('north');"/>

οnclick="startRequest('south');"/>

希望本文所述对大家的Ajax程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值