解析Ajax如何处理响应信息

ajax|响应

户的交互操作(interaction)驱动着Web站点。理解如何处理响应信息,特别是在使用新的交互操作形式(例如AJAX)的时候,这一点非常重要的。Kris Hadloc解释了AJAX请求-响应过程的本质,你应该了解这些内容,更好地为用户交互操作服务。

请求和响应

AJAX引擎分很多个方面,每个方面都很重要。如果引擎执行发送请求和接收响应信息的事务,那么它就有很多的处理响应信息的方法。响应信息是处理过程中的一个重要的部分,这是因为用户最终会与响应信息交互操作。本文详细解释了如何处理AJAX响应信息,并为用户提供反馈信息,根据需要进行更新。我们从请求的就绪状态开始,接着解释响应信息的状态、回调(callback)和分析响应信息。本文还解释了响应信息的其它一些方面,例如加载消息、错误处理和显示响应信息。

我建立了一个示例可供大家下载。这个示例包含了一个面向对象的AJAX引擎,你可以在任何AJAX应用程序中再次使用它。在讨论响应信息之前,我要指出如何建立AJAX引擎并发出请求。首先,让我们来看看AJAX引擎的代码(没有带上响应信息处理部分):


document.write("");

function Ajax()

{

 this.toString = function() { return "Ajax"; }

 this.http = new HTTP();

 this.makeRequest = function(_method, _url, _callbackMethod)

 {

this.request = (window.XMLHttpRequest)?

new XMLHttpRequest(): new ActiveXObject("MSXML2.XMLHTTP");

this.request.onreadystatechange = _callbackMethod;

this.request.open(_method, _url, true);

this.request.send(_url);

 }

}

为了建立这个对象并发出请求,你只需要使用下面两行代码:

var ajax = new Ajax();

ajax.makeRequest('GET', 'xml/content.xml', onResponse);

上面的第二行代码反映了你选择的请求方法、XML的路径或请求的服务器端脚本、当接收到响应信息时你希望调用的回调方法。现在你对AJAX引擎和如何发出请求已经有了一定的了解,我们来看看如何处理请求。

就绪(Ready)状态

就绪状态由回调方法来处理,当我们做出请求的时候,回调方法就已经设置好了。在例子中,onResponse被设置为回调方法,它在本文中被用于处理所有的分析代码的操作。我们将使用下面的代码来检测回调方法中的AJAX对象的就绪状态:

function onResponse()

{

 if(ajax.checkReadyState('body', 'loading...', 'loading...', 'loading...') == "OK")

 {

// 此处是分析代码

 }

}

上面的代码显示,我们将向checkReadyState方法传递四个参数。第一个参数是我们希望显示的加载(loading)消息div的ID、其它三个参数都是自定义的对应于不同状态的加载消息。我选择的用于加载消息的div的名字是body,它使得新数据在被载入的时候,内容和加载消息是合并在一起的。下面是实际的checkReadyState方法,它处理了我们刚才讨论的代码,并在div中向我们传递进去的参数来显示它。这个方法也被包含在示例AJAX引擎中了。


this.checkReadyState = function(_id, _1, _2, _3)

{

 switch(this.request.readyState)

 {

case 1:

 document.getElementById(_id).innerHTML = _1;

 break;

case 2:

 document.getElementById(_id).innerHTML = _2;

 break;

case 3:

 document.getElementById(_id).innerHTML = _3;

 break;

case 4:

 document.getElementById(_id).innerHTML = "";

 return this.http.status(this.request.status);

 }

}

checkReadyState方法为用户提供页面状态的反馈信息是有用处的。下表显示了它检测的值:

状态
0 Uninitialized(未初始化)
1 Loading(正在载入)
2 Loaded(已经载入)
3 Interactive(交互)
4 Complete(完成)

你可以为每种加载状态添加一个自定义的消息--它可以是一个简单的字符串,也可以是字符串格式的图片标签(例如显示一个动画的加载GIF)。下面就是一个例子:


var loader = "〈IMG src="http://images.51cto.com/wuyou/images/loader.gif"〉";

ajax.checkReadyState('body', loader, loader, loader);

 
不仅checkReadyState方法处理请求状态,它所包含的HTTP对象也会检测和返回请求的状态。

用户的交互操作(interaction)驱动着Web站点。理解如何处理响应信息,特别是在使用新的交互操作形式(例如AJAX)的时候,这一点非常重要的。Kris Hadloc解释了AJAX请求-响应过程的本质,你应该了解这些内容,更好地为用户交互操作服务。

请求和响应

AJAX引擎分很多个方面,每个方面都很重要。如果引擎执行发送请求和接收响应信息的事务,那么它就有很多的处理响应信息的方法。响应信息是处理过程中的一个重要的部分,这是因为用户最终会与响应信息交互操作。本文详细解释了如何处理AJAX响应信息,并为用户提供反馈信息,根据需要进行更新。我们从请求的就绪状态开始,接着解释响应信息的状态、回调(callback)和分析响应信息。本文还解释了响应信息的其它一些方面,例如加载消息、错误处理和显示响应信息。

我建立了一个示例可供大家下载。这个示例包含了一个面向对象的AJAX引擎,你可以在任何AJAX应用程序中再次使用它。在讨论响应信息之前,我要指出如何建立AJAX引擎并发出请求。首先,让我们来看看AJAX引擎的代码(没有带上响应信息处理部分):


document.write("");

function Ajax()

{

 this.toString = function() { return "Ajax"; }

 this.http = new HTTP();

 this.makeRequest = function(_method, _url, _callbackMethod)

 {

this.request = (window.XMLHttpRequest)? new XMLHttpRequest():

new ActiveXObject("MSXML2.XMLHTTP");

this.request.onreadystatechange = _callbackMethod;

this.request.open(_method, _url, true);

this.request.send(_url);

 }

}

为了建立这个对象并发出请求,你只需要使用下面两行代码:


var ajax = new Ajax();

ajax.makeRequest('GET', 'xml/content.xml', onResponse);

上面的第二行代码反映了你选择的请求方法、XML的路径或请求的服务器端脚本、当接收到响应信息时你希望调用的回调方法。现在你对AJAX引擎和如何发出请求已经有了一定的了解,我们来看看如何处理请求。

就绪(Ready)状态

就绪状态由回调方法来处理,当我们做出请求的时候,回调方法就已经设置好了。在例子中,onResponse被设置为回调方法,它在本文中被用于处理所有的分析代码的操作。我们将使用下面的代码来检测回调方法中的AJAX对象的就绪状态:


function onResponse()

{

 if(ajax.checkReadyState('body', 'loading...', 'loading...', 'loading...') == "OK")

 {

// 此处是分析代码

 }

}

上面的代码显示,我们将向checkReadyState方法传递四个参数。第一个参数是我们希望显示的加载(loading)消息div的ID、其它三个参数都是自定义的对应于不同状态的加载消息。我选择的用于加载消息的div的名字是body,它使得新数据在被载入的时候,内容和加载消息是合并在一起的。下面是实际的checkReadyState方法,它处理了我们刚才讨论的代码,并在div中向我们传递进去的参数来显示它。这个方法也被包含在示例AJAX引擎中了。


this.checkReadyState = function(_id, _1, _2, _3)

{

 switch(this.request.readyState)

 {

case 1:

 document.getElementById(_id).innerHTML = _1;

 break;

case 2:

 document.getElementById(_id).innerHTML = _2;

 break;

case 3:

 document.getElementById(_id).innerHTML = _3;

 break;

case 4:

 document.getElementById(_id).innerHTML = "";

 return this.http.status(this.request.status);

 }

}

checkReadyState方法为用户提供页面状态的反馈信息是有用处的。下表显示了它检测的值:

状态
0 Uninitialized(未初始化)
1 Loading(正在载入)
2 Loaded(已经载入)
3 Interactive(交互)
4 Complete(完成)

 
你可以为每种加载状态添加一个自定义的消息--它可以是一个简单的字符串,也可以是字符串格式的图片标签(例如显示一个动画的加载GIF)。下面就是一个例子:


var loader = "〈IMG src="http://images.51cto.com/wuyou/images/loader.gif"〉";

ajax.checkReadyState('body', loader, loader, loader);

不仅checkReadyState方法处理请求状态,它所包含的HTTP对象也会检测和返回请求的状态。

<

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ajax
, 方法
, 代码
, this
, 状态
, 信息
, 代码方法信息
, ajax请求
, 响应交互
, ajax显示正在加载
, Ajax接收请求
, ajax请求过程
, Ajax方法
ajax加载
servlet响应ajax请求、ajax响应时间过长、ajax响应时间、nodejs 响应ajax请求、ajax获取响应时间,以便于您获取更多的相关知识。

时间: 2024-11-05 16:31:14

解析Ajax如何处理响应信息的相关文章

Ajax如何处理响应信息

用户的交互操作(interaction)驱动着Web站点.理解如何处理响应信息,特别是在使用新的交互操作形式(例如AJAX)的时候,这一点非常重要的.Kris Hadloc解释了AJAX请求-响应过程的本质,你应该了解这些内容,更好地为用户交互操作服务. 请求和响应 AJAX引擎分很多个方面,每个方面都很重要.如果引擎执行发送请求和接收响应信息的事务,那么它就有很多的处理响应信息的方法.响应信息是处理过程中的一个重要的部分,这是因为用户最终会与响应信息交互操作.本文详细解释了如何处理AJAX响应

深入理解AJAX响应信息的处理(1)

ajax|响应 作者:陶刚编译出处:天极开发责任编辑: 方舟 [ 2006-03-09 17:26 ]用户的交互操作(interaction)驱动着Web站点 用户的交互操作(interaction)驱动着Web站点.理解如何处理响应信息,特别是在使用新的交互操作形式(例如AJAX)的时候,这一点非常重要的.Kris Hadloc解释了AJAX请求-响应过程的本质,你应该了解这些内容,更好地为用户交互操作服务. 请求和响应 AJAX引擎分很多个方面,每个方面都很重要.如果引擎执行发送请求和接收响

深入理解AJAX响应信息的处理

ajax|响应 用户的交互操作(interaction)驱动着Web站点.理解如何处理响应信息,特别是在使用新的交互操作形式(例如AJAX)的时候,这一点非常重要的.Kris Hadloc解释了AJAX请求-响应过程的本质,你应该了解这些内容,更好地为用户交互操作服务. 请求和响应 AJAX引擎分很多个方面,每个方面都很重要.如果引擎执行发送请求和接收响应信息的事务,那么它就有很多的处理响应信息的方法.响应信息是处理过程中的一个重要的部分,这是因为用户最终会与响应信息交互操作.本文详细解释了如何

深入理解AJAX响应信息的处理(2)

ajax|响应 请求状态 该AJAX对象的请求状态与被请求文件的HTTP状态是一样的.包含在AJAX文件中的HTTP对象处理了所有的W3C描述的HTTP状态代码定义,并把它们返回给请求方法.状态代码被分成了五个部分: · 信息的 1xx · 成功的 2xx · 重定向 3xx · 客户端错误 4xx · 服务器错误 5xx 上面的数字中的最前面一位表示某种类别的状态代码.例如,成功的是2xx,它的意思是包含了200-299之间的所有状态代码.HTTP对象检查状态代码的第一位数字,并根据代码所属的

HTTP状态代码及其定义解析 Ajax捕捉回调错误参考_AJAX相关

HTTP状态代码及其定义解析 Ajax捕捉回调错误参考  状态行包含HTTP版本.状态代码.与状态代码对应的简短说明信息.在大多数情况下,除了Content-Type之外的所有应答头都是可选的.但Content-Type是必需的,它描述的是后面文档的MIME类型.虽然大多数应答都包含一个文档,但也有一些不包含,例如对HEAD请求的应答永远不会附带文档.有许多状态代码实际上用来标识一次失败的请求,这些应答也不包含文档(或只包含一个简短的错误信息说明). 当用户试图通过 HTTP 访问一台正在运行

全面解析$.Ajax()方法参数(推荐)_AJAX相关

先给大家介绍下Ajax概念 AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和XML(标准通用标记语言的子集). AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. 传统的网页(不使用 AJAX)如果需要更新

HTTP状态代码及其定义解析 Ajax捕捉回调错误参考

HTTP状态代码及其定义解析 Ajax捕捉回调错误参考 状态行包含HTTP版本.状态代码.与状态代码对应的简短说明信息.在大多数情况下,除了Content-Type之外的所有应答头都是可选的.但Content-Type是必需的,它描述的是后面文档的MIME类型.虽然大多数应答都包含一个文档,但也有一些不包含,例如对HEAD请求的应答永远不会附带文档.有许多状态代码实际上用来标识一次失败的请求,这些应答也不包含文档(或只包含一个简短的错误信息说明). 当用户试图通过 HTTP 访问一台正在运行 I

全面解析$.Ajax()方法参数(推荐)

先给大家介绍下Ajax概念 AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和XML(标准通用标记语言的子集). AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. 传统的网页(不使用 AJAX)如果需要更新

AJAX如何处理书签和翻页按扭

ajax|翻页|翻页按扭|书签 本篇文章提供了一个开源JavaScript库,它提供了给AJAX应用程序中添加书签和会退按钮的功能.在学习完这个教程后,开发者将能够对开发AJAX应用碰到的问题获得一个解决方案,这个特性甚至Google Maps 和 Gmail 现在都不提供:提供一个强大的,可用的书签和前进回退按钮,如同其他的WEB应用一样的行为. AJAX"如何处理书签和回退按钮"阐述了AJAX应用程序开发书签和回退按钮功能碰到的严重的问题:可以解决以上问题的一个开源框架,并提供真实