我们先来看看异步对象五部曲
这是post请求的、
代码如下:
属性传递
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
//4.0设置回调函数
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
alert(xhr.responseText);
}
}
//5.0传递参数
xhr.send(params);
结合get请求做一个异步对象的封装
get 请求中的
xhr.setRequestHeader("If-Modified-Since","0"); 是为了清除缓存
而post请求的
代码如下:
是为了传输方式
在 <div class="codetitle"><a style="CURSOR: pointer" data="32178" class="copybut" id="copybut32178" onclick="doCopy('code32178')"> 代码如下:
var ajaxHelp = {
CreatXHR: function () {
//创建异步对象
var xhr = new XMLHttpRequest();
return xhr;
},
//ajax的get请求
AjaxGet: function (url,callBack) {
this.AJaxCommon("get",null,callBack);
},
//ajax的post请求
AjaxPost: function (url,callBack) {
this.AJaxCommon("post",
AJaxCommon: function (method,callBack) {
//1.0
var xhr = this.CreatXHR();
//2.0
xhr.open(method,true);
//3.0
if (method == "get") {
xhr.setRequestHeader("If-Modified-Since","0");
} else {
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
}
//4.0
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) {
var datas = JSON.parse(xhr.responseText);
//执行回调函数
callBack(datas);
}
}
//5.0
xhr.send(params);
}
};