完全解析看如何处理响应信息的

更新时间:2021-10-29 05:54:02

请求状态  该AJAX对象的请求状态与被请求文件的HTTP状态是一样的。包含在AJAX文件中的HTTP对象处理了所有的W3C描述的HTTP状态代码定义,并把它们返回给请求方法。状态代码被分成了五个部分:

· 信息的 1xx   · 成功的 2xx   · 重定向 3xx   · 客户端错误 4xx   · 服务器错误 5xx  上面的数字中的最前面一位表示某种类别的状态代码。例如,成功的是2xx,它的意思是包含了之间的所有状态代码。HTTP对象检查状态代码的第一位数字,并根据代码所属的类别,执行一次转换。在检测出类别之后,HTTP对象把它发送给响应方法,该方法把状态代码作为字符串的形式返回。这就是HTTP状态方法:

atus = function(_status)

{

var s = _String().split(\"\");

switch(s[0])

导读:大家是否还记得PSP上的《超时空要塞F》呢?现在系列最新作即将再次登陆PSP啦!新作名为《超时空要塞 终极边境》 {

case \"1\":

return tInformationalStatus(_status);

break;

case \"2\":

return tSuccessfulStatus(_status);

break;

case \"3\":

return tRedirectionStatus(_status);

break;

case \"4\":

return tClientErrorStatus(_status);

break;

case \"5\":

return tServerErrorStatus(_status);

break;

}

}

状态代码是通过检测该代码的第一位数字来处理的。一旦完成了代码检测,原始的状态代码就被发送到一个适当的方法中,该方法给onResponse方法发送一个字符串形式的状态代码。接着我们就可以把这条消息显示给用户,如果遇到了什么错误,她/他就知道发生了什么情况。另一方面,如果请求是成功的,那么就显示数据。

ResponseText和ResponseXML

响应信息的内容可能有多种不同的形式,例如XML、纯文本、(X)HTML或JavaScript对象符号(JSON)。我们可以根据所接收到的数据格式的不同,用两种不同的方法来处理:使用responseText或者responseXML。responseText方法用于那些并非基于XML的格式。它把响应信息作为字符串,返回精确的内容。纯文本、(X)HTML和JSON都使用responseText。在纯文本或HTML上使用这个方法是很简单的:

if(eckReadyState(\'body\', \'loading...\', \'loading...\', \'loading...\') == \"OK\")

{

tElementById(\'body\').innerHTML = sponseText;

}

它最简单不过了!一旦载入响应信息完成,我们就调用AJAX对象,用responseText来检索它的值,并把它添加到页面上。

处理JSON响应信息比处理纯文本或(X)HTML需要多一点技巧。下面是我们分析一个JSON文件的示例:

{ \'header\' : \'How to Handle the Ajax Response\',

\'description\' : \'An in-depth explanation of how to handle the Ajax response.\',

\'sourceUrl\' : \'\'}

数据被冒号(:)分成了两个部分:标签名称和值。附加的数据被逗号(,)分成新的名称/值对。现在我们知道了JSON的样子了,下面是我们分析它的方法:

if(eckReadyState(\'body\', \'loading...\', \'loading...\', \'loading...\') == \"OK\")

{

eval(\"var response = (\"+sponseText+\")\");

tElementById(\'body\').innerHTML = \"b\" + ader + \"/bbr/\"

+ scription + \"br/br/\"

+ \"a href=\'\" + urceUrl + \"\'Download the source files/a\";

}

JSON数据首先由JavaScript来分析(使用简单的eval()过程)。一旦数据被分析好了并建立了响应信息对象,我们就可以简单地通过名字来获取它们的响应信息值。

responseText不仅可以给页面添加内容,它在调试AJAX请求的时候也有用处。例如,你可能还没有准备好分析数据,因为你还不知道所有的标签是什么样的,是XML格式的还是JSON文件。这就要求有一种用于检测被分析数据的途径。一旦你知道了所有的标签名称,所需要做的事情就只是编写代码了。

responseXML的使用也相当简单。但是与JSON格式类似,XML要求进行数据分析。我们需要执行的第一项事务是识别出XML响应信息中的根节点。

var response = cumentElement;

下一步,我们通过名称获取所有的元素并得到它们的值:

var header = tElementsByTagName(\'header\')[0].ta;

var description = tElementsByTagName(\'description\')[0].ta;

var sourceUrl = tElementsByTagName(\'sourceUrl\')[0].ta;

最后,我们把响应信息显示在相应的div标记中:

tElementById(\'body\').innerHTML = \"b\" + header + \"/bbr/\"

+ description + \"br/br/\"

+ \"a href=\'\" + sourceUrl + \"\'Download the source files/a\";

用JavaScript的时候,JSON比XML要快一些,这是因为JSON所需要的分析代码比XML少很多,直接导致在分析大量数据的时候,JSON的速度较快。JSON不如XML的地方在于XML受到的支持更大、服务器端开发选项更多。你可以根据环境和请求的用途来做出选择。

AJAX响应信息是AJAX通讯中的一个重要的部分。你需要处理很多方面的信息,包括就绪状态、错误处理和加载状态,并最终显示出来。有了这些信息之后,你就可以把注意力集中在响应信息上,为用户提供更多的信息。

北京妇科习惯性流产治疗费用
胃溃疡的症状有哪些
绵阳白癜风最好医院
友情链接
1