该XMLHttpRequest对象使您可以定义要执行的函数以处理响应。
响应函数onreadystatechange在XMLHttpRequest对象的属性中定义。
httpRequest.onreadystatechange = function() {
if (this.readyState === 4 && this.status === 200) {
document.getElementById("output").innerHTML = this.responseText;
}
};
该onreadystatechange属性定义当readyState更改时要执行的函数。
该readyState属性保存XMLHttpRequest对象的状态。
该status属性保存XMLHttpRequest对象的状态代码。
该statusText属性保存XMLHttpRequest对象的状态文本。
属性 | 描述 |
---|---|
onreadystatechange | 定义当readyState属性更改时要调用的函数 |
readyState | 保持XMLHttpRequest的状态: 0:请求未初始化 1:服务器连接建立 2:收到请求 3:处理请求 4:请求完成并且响应准备就绪 |
status | 返回请求的状态号: 200:“OK” 403:“Forbidden” 404:“Not Found” 有关完整列表,请访问HTTP状态代码参考 |
statusText | 返回状态文本(例如,“OK”或“Not Found”) |
服务器响应属性
下表列出了服务器响应属性:
属性 | 描述 |
---|---|
responseText | 以字符串形式返回响应数据 |
responseXML | 将响应数据作为XML数据返回 |
responseText属性
该responseText属性以JavaScript字符串形式返回服务器响应。
document.getElementById("output").innerHTML = httpRequest.responseText;
responseXML属性
该responseXML属性将服务器响应作为XMLDocument对象返回。
您可以使用JavaScript DOM函数遍历XMLDocument对象。
以下示例请求文件ajax_test.xml并解析响应:
xmlDoc = httpRequest.responseXML;
tag = xmlDoc.getElementsByTagName("author");
for (let i = 0; i < tag.length; i++) {
txt += tag[i].childNodes[0].nodeValue + "<br>";
}
httpRequest.open("GET", "ajax_test.xml", true);
httpRequest.send();
服务器响应方法
下表列出了服务器响应方法:
方法 | 描述 |
---|---|
getAllResponseHeaders() | 返回标题信息 |
getResponseHeader() | 返回特定的标头信息 |
getAllResponseHeaders()方法
该getAllResponseHeaders()方法从服务器响应中返回所有标头信息。
var httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = function() {
if (this.readyState === 4 && this.status === 200) {
document.getElementById("output").innerHTML = this.getAllResponseHeaders();
}
};
getResponseHeader()方法
该getResponseHeader()方法从服务器响应中返回特定的标头信息。
var httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = function() {
if (this.readyState === 4 && this.status === 200) {
document.getElementById("output").innerHTML = this.getResponseHeader("Server");
}
};
多个AJAX任务
如果网站中有多个AJAX任务,则应创建两个功能:
-
一种执行XMLHttpRequest对象的函数
-
每个AJAX任务都有一个回调函数
函数调用应包含URL以及响应就绪后要调用的函数。
fetchDoc("url-1", myFunc1);
fetchDoc("url-2", myFunc2);
fetchDoc("url-3", myFunc3);
function fetchDoc(url, callback) {
var httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = function() {
if (this.readyState === 4 && this.status === 200) {
callback(this);
}
};
httpRequest.open("GET", url, true);
httpRequest.send();
}
function myFunc1(httpRequest) {
// action goes here
}
function myFunc2(httpRequest) {
// action goes here
}
function myFunc3(httpRequest) {
// action goes here
}
回调函数是作为参数传递给另一个函数的函数。