本文實(shí)例講述了AJAX+JSP實(shí)現(xiàn)讀取XML內(nèi)容并按排列顯示輸出的方法。分享給大家供大家參考,具體如下:
實(shí)現(xiàn)功能:點(diǎn)擊按扭,顯示出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 的幾個(gè)步驟: 1、建立XmlHttpRequest對(duì)象 2、設(shè)置回調(diào)函數(shù) 3、使用Open方法建立與服務(wù)器的連接 4、向服務(wù)器發(fā)送數(shù)據(jù) 5、在回調(diào)函數(shù)中針對(duì)不同響應(yīng)狀態(tài)進(jìn)行處理 */ var xmlHttp; function createXMLHttpRequest(){ //1建立XmlHttpRequest對(duì)象 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設(shè)置回調(diào)函數(shù) if(xmlHttp.readyState==4){ //數(shù)據(jù)接收完成并可以使用 if(xmlHttp.status==200){ //http狀態(tài)OK //5、在回調(diào)函數(shù)中針對(duì)不同響應(yīng)狀態(tài)進(jìn)行處理 // document.getElementById("sp").innerHTML = xmlHttp.responseText; //服務(wù)器的響應(yīng)內(nèi)容 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("出錯(cuò):"+xmlHttp.statusText); //HTTP狀態(tài)碼對(duì)應(yīng)的文本 } } } /** //這是GET方法傳送 function getMes(){ createXMLHttpRequest(); var txt = document.getElementById("txt").value; var url="servlet/AjaxServlet?txt="+txt; url = encodeURI(url); //轉(zhuǎn)換碼后再傳輸 xmlHttp.open("GET",url,true); //3使用Open方法建立與服務(wù)器的連接 xmlHttp.onreadystatechange=showMes; xmlHttp.send(null); //4向服務(wù)器發(fā)送數(shù)據(jù) } */ /** *這是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:這里再為大家提供幾款關(guān)于xml操作的在線工具供大家參考使用:
在線XML/JSON互相轉(zhuǎn)換工具:
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
更多關(guān)于ajax相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結(jié)》、《JavaScript中ajax操作技巧總結(jié)》、《PHP+ajax技巧與應(yīng)用小結(jié)》及《asp.net ajax技巧總結(jié)專題》
希望本文所述對(duì)大家ajax程序設(shè)計(jì)有所幫助。
標(biāo)簽:德陽 婁底 邯鄲 海南 黔東 樂山 內(nèi)江 衡陽
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《AJAX+JSP實(shí)現(xiàn)讀取XML內(nèi)容并按排列顯示輸出的方法示例》,本文關(guān)鍵詞 AJAX+JSP,實(shí)現(xiàn),讀取,XML,內(nèi)容,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。