开发者社区> 聚优云惠> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

AJAX服务器异步通信

简介: 首先简单的了解一下下什么是Ajax:        AJAX是一种运用JavaScript和可扩展编辑语言(XML),在网络浏览器和服务器之间传送或接收数据的技术。
+关注继续查看


首先简单的了解一下下什么是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 plaincopy
  1. <script language ="javascript">  
  2.    //定义一个将指向XMLHttpRequest对象的变量  
  3.    var xmlHttp = null;  
  4.    //定义一个函数用于创建XMLHttpRequest对象  
  5.    function createXMLHttpRequest(){  
  6.        if(window.ActiveXObject){            //表示当前浏览器是IE  
  7.            xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");  
  8.        }  
  9.        else if(window.XMLHttpRequest){        
  10.            xmlHttp = new XMLHttpRequest();     //表示当前浏览器不是IE,如:firefox  
  11.        }  
  12. }  
  13.    
  14.    //定义一个函数用于启动与服务器的异步通信  
  15.    function begin(){  
  16.        createXMLHttpRequest();                 //调用createXMLHttpRequest函数  
  17.        xmlHttp.onreadystatechange = processor;     //将事件触发器绑定到 processor上  
  18.        xmlHttp.open("GET""test.xml"true);     //使用GET方法建立对服务器资源test.xml的一个异步调用  
  19.        xmlHttp.send(null);                      //向服务器发送请求 ,参数为null  
  20. }  
  21.    
  22.    //定义一个状态处理函数用于处理状态触发器的状态改变  
  23.    function processor(){  
  24.        //如果处理请求完成  
  25.        if(xmlHttp.readyState == 4){  
  26.            //如果服务器返回状态为成功  
  27.            if(xmlHttp.status = 200){  
  28.                 //将从服务器返回的内容报告给用户  
  29.                 alert("从服务器返回的内容为:"+ xmlHttp.responseText);  
  30.            } else{  
  31.                 alert("请求失败,错误码="+ xmlHttp.status);  
  32.            }  
  33.        }  
  34.     }  
  35. </script>  

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
使用SpringMvc跨服务器上传图片,Ajax异步刷新图片框显示图片功能请求不到后台,onChange事件没有激活的源码?
使用SpringMvc跨服务器上传图片,Ajax异步刷新图片框显示图片功能请求不到后台,onChange事件没有激活的源码?
0 0
第105天:Ajax 客户端与服务器基本知识
一、服务器 前言:通俗的讲,能够提供某种服务的机器(计算机)称为服务器 1、服务器类型 - 按服务类型可分为:文件服务器、数据库服务器、邮件服务器、Web服务器等 - 按操作系统可分为:Linux服务器、Windows服务器等 - 按应用软件可分为:Apache服务器、Nginx 服务器、IIS服务器、Tomcat服务器、 weblogic服务器、WebSphere服务器、boss服务器、 Node服务器等 2、 服务器软件     使计算机具备提供某种服务能力的应用软件,称为服务器软件, 通过安装相应的服务软件,然后进行配置后就可以使计算具备了提供某种服务的能力。
1001 0
Ajax 请求其它服务器
把跨域的url传给服务器 让服务器去作为浏览器去请求 然后把结果传给客户端   云代理  申请个控件 然后做成代理的 你把url传给云 让云拿内柔再传回来   google app engin
483 0
jQuery封装Ajax,SpringMVC使用Ajax的配置
jQuery封装Ajax,SpringMVC使用Ajax的配置
0 0
JQuery Ajax实现三级联动
本文实例为大家分享了ajax实现三级联动的具体代码
0 0
jQuery中的Ajax
jQuery中的Ajax
0 0
+关注
聚优云惠
专业科普建站知识 ,让建站变得更简单。专注于WordPress和Java建站知识讲解,云服务器主机知识讲解,建站程序搭建和网站优化。 欢迎访问我的网站 :http://tencent.yundashi168.com
文章
问答
文章排行榜
最热
最新
相关电子书
更多
函数计算事件驱动的无服务器计算服务
立即下载
网站/服务器取证 实践与挑战
立即下载
网站/服务器取证实践与挑战
立即下载