本文實例講述了AJAX+JSP實現讀取XML內容并按排列顯示輸出的方法。分享給大家供大家參考,具體如下:
實現功能:點擊按扭,顯示出JSP頁面中通過out.println傳過來的xml信息
一、含XML的JSP頁面
%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
%
response.setContentType("text/xml");
String txt = request.getParameter("username");
out.println("student>name>張三/name>age>21/age>sex>男/sex>/student>");
%>
二、AJAX處理并顯示返回頁面
%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
html>
head>
title>ajax02/title>
script type="text/javascript">
/*
ajax 的幾個步驟:
1、建立XmlHttpRequest對象
2、設置回調函數
3、使用Open方法建立與服務器的連接
4、向服務器發送數據
5、在回調函數中針對不同響應狀態進行處理
*/
var xmlHttp;
function createXMLHttpRequest(){ //1建立XmlHttpRequest對象
if(window.ActiveXObject){
try{
alert("Msxml2.XmlHttp.5.0");
xmlHttp = new ActiveXObject("Msxml2.XmlHttp.5.0");
}catch(e){
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHttp");
}catch(e){
alert("Microsoft.XMLHttp");
}
}
}else{
xmlHttp = new XMLHttpRequest();
}
}
function showMes(){ //2設置回調函數
if(xmlHttp.readyState==4){ //數據接收完成并可以使用
if(xmlHttp.status==200){ //http狀態OK
//5、在回調函數中針對不同響應狀態進行處理
// document.getElementById("sp").innerHTML = xmlHttp.responseText; //服務器的響應內容
var name = xmlHttp.responseXML.getElementsByTagName("name")[0].firstChild.nodeValue;
var age = xmlHttp.responseXML.getElementsByTagName("age")[0].firstChild.nodeValue;
var sex = xmlHttp.responseXML.getElementsByTagName("sex")[0].firstChild.nodeValue;
document.getElementById("spanname").innerHTML = name;
document.getElementById("spanage").innerHTML = age;
document.getElementById("spansex").innerHTML = sex;
}else{
alert("出錯:"+xmlHttp.statusText); //HTTP狀態碼對應的文本
}
}
}
/**
//這是GET方法傳送
function getMes(){
createXMLHttpRequest();
var txt = document.getElementById("txt").value;
var url="servlet/AjaxServlet?txt="+txt;
url = encodeURI(url); //轉換碼后再傳輸
xmlHttp.open("GET",url,true); //3使用Open方法建立與服務器的連接
xmlHttp.onreadystatechange=showMes;
xmlHttp.send(null); //4向服務器發送數據
}
*/
/**
*這是post方法
*/
function postMes(){
createXMLHttpRequest();
var txt = document.getElementById("txt").value;
// var url = "servlet/AjaxServlet";
var url = "work02forxml-2.jsp"
var params = "username="+txt;
xmlHttp.open("POST",url,true);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=UTF-8");
xmlHttp.send(params);
xmlHttp.onreadystatechange = showMes;
}
/script>
/head>
body>
input type="text" id="txt"/>
input type="button" value="query" onclick="postMes()" />br>
span id="sp">/span>
姓名:span id="spanname">/span>br>
年齡:span id="spanage">/span>br>
性別:span id="spansex">/span>
/body>
/html>
PS:這里再為大家提供幾款關于xml操作的在線工具供大家參考使用:
在線XML/JSON互相轉換工具:
http://tools.jb51.net/code/xmljson
在線格式化XML/在線壓縮XML:
http://tools.jb51.net/code/xmlformat
XML在線壓縮/格式化工具:
http://tools.jb51.net/code/xml_format_compress
XML代碼在線格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat
更多關于ajax相關內容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結》、《JavaScript中ajax操作技巧總結》、《PHP+ajax技巧與應用小結》及《asp.net ajax技巧總結專題》
希望本文所述對大家ajax程序設計有所幫助。
您可能感興趣的文章:- JQuery的ajax獲取數據后的處理總結(html,xml,json)
- AJAX使用post發送數據xml格式接受數據
- 用Ajax讀取xml文件的簡單例子
- Jquery Ajax學習實例 向頁面發出請求,返回XML格式數據
- AJAX中同時發送多個請求XMLHttpRequest對象處理方法
- 通過XMLHttpRequest和jQuery實現ajax的幾種方式
- JS通過ajax動態讀取xml文件內容的方法
- AJAX 常用函數創建XMLHTTP對象,區別IE,Mozilla瀏覽器
- javascript解析ajax返回的xml和json格式數據實例詳解
- firefox下jquery ajax返回object XMLDocument處理方法
- 用Ajax讀取XML格式的數據