Ajax 编程步骤
AJAX 请求基本架构
AJAX请求基本步骤:
Step01:获取Ajax 请求对象(由浏览器端的Ajax引擎提供)
Step02:设置Ajax对象的状态监听(通讯和响应状态)
Step03:创建Ajax请求连接(与服务端建立连接)
Step04:发送Ajax异步请求(发送到服务端)
Ajax编程实现(了解)
Ajax 异步GET请求
通过ajax请求异步获取服务端日志信息,并局部刷新页面
Step01:设置dom状态监听
window.onload=function(){
doGetObjects();
console.log("hello ajax");
}//dom事件
Step02:定义事件处理函数通过ajax获取数据
function doGetObjects(){
//1.创建ajax请求对象(是实现ajax应用的一个入口对象)
var xhr=new XMLHttpRequest();
console.log(xhr);
//2.设置ajax对象的状态监听(响应是否结束)
xhr.onreadystatechange=function(){
//基于请求响应状态处理结果
//4表示服务端响应结束,200表示服务端响应OK(正确)
if(xhr.readyState==4&&xhr.status==200){
//responseText为服务端响应的文本
console.log(xhr.responseText);//string
doHandleResponseResult(xhr.responseText);
}
}
//3.发送ajax请求
doSendGetRequest(xhr)
}
发送GET请求
//发送GET请求
function doSendGetRequest(xhr){
//3.1.建立与服务端的连接
var url="doFindPageObjects.do?pageCurrent=1"
xhr.open("GET",url,true);//true表示异步(底层会启动工作线程)
//3.2.发送请求
xhr.send(null);//get请求此位置不传数据
}
数据处理函数定义
function doHandleResponseResult(resultStr){
//1.将json格式的字符串转换json格式的JavaScript object
var result=JSON.parse(resultStr);
console.log(result);
//2.处理数据
if(result.state==1){
//将记录显示到tbody中
doSetTableBodyRows(result.data.records);
}else{
alert(result.message);
}
}
显示数据方法定义
//在tbody中显示记录信息
function doSetTableBodyRows(records){
//1.获取tbody对象,并清空内容
var tBody=document.getElementById("tbodyId");
tBody.innerHTML="";
//2.将records数据追加tbody中
for(var i=0;i
2.2.2.Ajax 异步post请求
发送POST请求,可以将此方法替换发送GET请求的方法
function doSendPostRequest(xhr){
//3.1.建立与服务端的连接
var url="doFindPageObjects.do"
xhr.open("POST",url,true);//true表示异步(底层会启动工作线程)
//post请求必须设置此请求头
xhr.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");
//3.2.发送请求
xhr.send("pageCurrent=1");//post请求此位置传数据
}
JQuery中的Ajax应用
ajax 函数应用
juqery 中的ajax函数用于向服务端发起一个异步的ajax请求.
例如:
$.ajax({ url: "address",
type:”GET”,
data: { param1: "foo bar", param2: "baz“ },
dataType: "json",
success: successHandlerFunction,
error: errorHandlerFunction,
cache: false,
})
Ajax 函数应用案例
$(function() {
$("#data-button-2").click(processAjaxRequest);
});
function processAjaxRequest () {
var params ={ param1: $("#field3").val(),param2: $("#field4").val() };
$.ajax({ url: "doFindPageObjects.do",
data: params,
success: function(result){
……..
} );
}
load函数应用
jquery 中的load函数一般用于在某个位置异步加载某个url页面,
语法:load(url,[data],[callback])
其中:
1)url 表示远程一个地址
2)data 表示要传递数据(key/value)
3)callback 表示一个回调函数
例如: 案例1
$("#time-result-1").load("listUI.do");
例如: 案例2
$("body").load("listUI.do",{color:red},function(){
…..
});
getJson函数应用
Jquery中的getJSON函数用于向服务端发起Ajax GET请求
获取json格式的数据
语法:
$.getJSON("url",[data], [callback])
例如:
$.getJSON(“doFindPageObjects.do”,{pageCurrent:1},function(result){
//处理返回结果
})
post 函数应用
POST方法为Jquery中的发送Ajax post请求的一种方法.
语法:post(url,[data],[callback])
例如:
$.post("doFindPageObjects.do",{pageCurrent:1},function(result){
…..
})
jsp页面代码(WEB-INF_pages_jsp)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
Insert title here
日志列表页面
<%=new java.util.Date()%>
id
username
operation
数据加载中...