微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AJAX处理以XML返回的响应

Ajax请求,服务器端返回XML形式的数据,在页面上用Javascript处理会非常方便。

代码

// 发送请求
var req;
		
function getXMLHttpRequest() {
	var xRequest = null;
	if (window.XMLHttpRequest) {
		xRequest = new XMLHttpRequest();
	} else if (typeof ActiveXObject != "undefined") {
		xRequest = new ActiveXObject("Microsoft.XMLHTTP");
	}
	return xRequest;
}
		
function sendRequest(url,params,HttpMethod,callback) {
	if (!HttpMethod) {
		HttpMethod = "GET";
	}
	req = getXMLHttpRequest();
	if (req) {
		req.onreadystatechange = callback;
		req.open(HttpMethod,url,true);
		req.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=EUC-JP"); 
		req.send(params);
	}
}
// 回调函数
function change() {
            if (xmlHttp.readyState == 4) {
                if (xmlHttp.status == 200) {
                    var data = xmlHttp.responseXML;
                    var datas = data.getElementsByTagName('info');
                    for (var i = 0; i < datas.length; i++) alert(datas[i].firstChild.nodeValue);
                    datas = data.getElementsByTagName('memo');
                    for (i = 0; i < datas.length; i++) alert(datas[i].firstChild.nodeValue);
                }
            }
        }
// 服务器端代码

// XML头,没有这个Javascript解析不出XML,编码一定要设,要不然会乱码
StringBuilder infoBuilder = new StringBuilder("<?xml version=\"1.0\" encoding=\"EUC-JP\"?>");
// 根元素<root></root>一定需要,否则Javascript解析不出XML,但名字不一定要叫root
infoBuilder.append(("<root><info>a</info><info>b</info><memo>c</memo><memo>d</memo></root>");
);

PrintWriter writer = null;
		try {
			
			// 设置编码
response.setContentType("text/xml;charset=EUC-JP");
			writer = response.getWriter();
			writer.println(infoBuilder.toString());
			writer.flush();
		} catch (Exception e) {
			
		} finally {
			if (writer != null) writer.close();
		}

原文地址:https://www.jb51.cc/ajax/163526.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐