本文實例講述了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程序設計有所幫助。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com