原生JS中的使用
function test(){
var data=$(...).val();
var req=new XMLHttpRequest();
req.open("post","AjaxServlet",true);
req.setRequestHeader("Content-type","application/x-www-form-urlencoded");
req.send("username="+username);
req.onreadystatechange=function(){
if(req.readyState==4){
if(req.status==200){
var str=req.responseText;
var arr = eval("("+str+")");
for(var i=0;i<arr.length;i++){
alert(arr[i].name);
}
}
}
}
}
jQuery中的使用,大大简化
function test(){
$.get("AjaxServlet",{"account":"zhs","password":"123"},function(data){
alert(data);
alert(data.name+"-"+data.account);
},"json");
$.post("AjaxServlet",{"account":"zhs","password":"123"},function(data){
alert(data);
alert(data.name+"-"+data.account);
},"json")
$.ajax({
url:"AjaxServlet",
data:{"account":"zhs","password":"123"},
type:"get",
dataType:"json",
async:true,
success:function(data){
alert(data.name);
}
})
$("p").load("AjaxServlet",{"account":"zhs","password":"123"},function(responseText,statusText,xhr){
eval("("+responseText+")")
})
}
Servlet中数据处理回调给AJAX
package com.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.aowin.model.User;
@WebServlet("/AjaxServlet")
public class AjaxServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
User u = new User("zhs","123","张三");
JSONObject.toJSONString(u);
ArrayList<User> al=new ArrayList<>();
al.add(u);
al.add(new User("lsii", "123", "李四"));
String json = JSONArray.toJSONString(al);
PrintWriter out = response.getWriter();
out.print(json);
out.flush();
out.close();
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}