AJAX服务器异步通信

前端之家收集整理的这篇文章主要介绍了AJAX服务器异步通信前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。


首先简单的了解一下下什么是Ajax:

AJAX是一种运用JavaScript和可扩展编辑语言(XML),在网络浏览器和服务器之间传送或接收数据的技术。

AJAX是WEB2.0的核心之一.AJAX技术运用于浏览器中,使向服务器索取网页的部分信息成为可能.

再简单的了解一下下它的工作原理:

AJAX的工作原理相当与在用户和服务器之间加了一个中间层,使用户请求与服务器响应异步化(我们经常用它来做数据校验)。这样还可以把以前的一些服务器负担的工作转交给客户端,利用客户端闲置的处理能力来处理这些工作,减轻服务器和宽带的负担,同时也可以缩短用户等待时间,提高工作效率。

这样说有点抽象,看两个图就明白了:

上图为没有使用异步通信技术的事件请求,明显的看出只有得到通知后才能继续输入密码和其它需要的信息,这样是不是很浪费时间,有时候时间长了,用户也可能会等的不耐烦,放弃注册也不是没有可能。


上图为使用了异步通信技术后的事件请求,用户不用等待消息的返回,继续输入就可以了,当用户输入到下面的某一项时,通知的消息可能就返回了,在相应的地方给出提示,这样也不影响用户的操作,是不是很友好,很强大。

AJAX的核心是JavaScript对象XMLHttpRequest

XMLHttpRequest提供客户端同HTTP服务器异步通信的协议.通过这个协议,AJAX可以使页面像桌面程序一样同服务器端进行数据层面的交换,而不必每次都刷新页面,也不用每次都将数据处理的工作都交给服务器来做,这样既减轻了服务器负担又加快了响应速度,缩短了用户等待的时间.

了解几个XMLHttpRequest对象的方法

Abort()

停止当前请求

getAllResponseHeaders()

返回HTTP请求的所有响应头部的键/值字符串

getResponseHeader("header")

返回指定头部属性的字符串值

Open("method","url",true)

建立对服务器的调用。Method参数可以是GET POST PUT,url参数可以是相对URL或绝对URL,true/false代表是否要进行异步通信

Send(content)

向服务器发送请求(要是get提交参数为null)

setRequestHeader("header","value")

为指定头部属性设置指定值

了解几个XMLHttpRequest对象的属性

Onreadystatechange状态改变的时间触发器,通常绑定一个JavaScript 函数,每当状态发生改变时,就调用函数

readyState 请求的状态,有5个可取值:

0 = 未初始化

1 = 读取中

2 = 已读取

3 = 交互中

4 =完成

responseText 从服务器返回的文本形式的响应内容

responseXML 从服务器返回的兼容DOM的XML文档对象

Status从服务器返回的状态码,例如404="文件找不到"200 = "成功"

statusText从服务器返回的状态文本信息,例如OKNot Found(未找到)

最后我们一起了解一下实现代码有详细的注释,看了就懂):

[javascript] view plain copy
  1. <scriptlanguage="javascript">
  2. //定义一个将指向XMLHttpRequest对象的变量
  3. varxmlHttp=null;
  4. //定义一个函数用于创建XMLHttpRequest对象
  5. functioncreateXMLHttpRequest(){
  6. if(window.ActiveXObject){//表示当前浏览器是IE
  7. xmlHttp=newActiveXObject("Microsoft.XMLHTTP");
  8. }
  9. elseif(window.XMLHttpRequest){
  10. xmlHttp=newXMLHttpRequest();//表示当前浏览器不是IE,如:firefox
  11. }
  12. //定义一个函数用于启动与服务器的异步通信
  13. functionbegin(){
  14. createXMLHttpRequest();//调用createXMLHttpRequest函数
  15. xmlHttp.onreadystatechange=processor;//将事件触发器绑定到processor上
  16. xmlHttp.open("GET","test.xml",true);//使用GET方法建立对服务器资源test.xml的一个异步调用
  17. xmlHttp.send(null);//向服务器发送请求,参数为null
  18. //定义一个状态处理函数用于处理状态触发器的状态改变
  19. functionprocessor(){
  20. //如果处理请求完成
  21. if(xmlHttp.readyState==4){
  22. //如果服务器返回状态为成功
  23. if(xmlHttp.status=200){
  24. //将从服务器返回的内容报告给用户
  25. alert("从服务器返回的内容为:"+xmlHttp.responseText);
  26. }else{
  27. alert("请求失败,错误码="+xmlHttp.status);
  28. </script>

猜你在找的Ajax相关文章