提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事。发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式。你现在传输,我要亲眼看你传输完成,才去做别的事 。
请求通过事件触发->服务器处理(这时浏览器仍然可以作其他事情)->处理完毕。发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式 。你传输吧,我去做我的事了,传输完了告诉我一声 。
Ajax被认为是(Asynchronous JavaScript and XML的缩写)。现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax.
Ajax并非一种新的技术,而是几种原有技术的结合体。它由下列技术组合而成:
1.使用CSS和XHTML来表示。
2. 使用DOM模型来交互和动态显示。
3.使用XMLHttpRequest来和服务器进行异步通信。
4.使用javascript来绑定和调用。
AJAX的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。
XMLHttpRequest是ajax的核心机制,它是在IE5中首先引入的,是一种支持异步请求的技术。简单的说,也就是javascript可以及时向服务器提出请求和处理响应,而不阻塞用户。达到无刷新的效果。
XMLHttpRequest属性有:
属性 | 描述 |
onreadystatechange | 每次状态改变所触发事件的事件处理程序。 |
responseText | 从服务器进程返回数据的字符串形式。 |
responseXML | 从服务器进程返回的DOM兼容的文档数据对象。 |
status | 从服务器返回的数字代码,比如常见的404(未找到)和200(已就绪) |
status Text | 伴随状态码的字符串信息 |
readyState | 对象状态值,存有服务器响应的状态信息。 每当 readyState 改变时,onreadystatechange 函数就会被执行。 |
readyState 属性可能的值:
状态 | 描述 |
---|---|
0 | 请求未初始化(在调用 open() 之前) |
1 | 请求已提出(调用 send() 之前) |
2 | 请求已发送(这里通常可以从响应得到内容头部) |
3 | 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应) |
4 | 请求已完成,此时可以通过通过responseXml和responseText获取完整的回应数据。 |
但是,由于各浏览器之间存在差异,所以创建一个XMLHttpRequest对象可能需要不同的方法。这个差异主要体现在IE和其它浏览器之间。下面是一个比较标准的创建XMLHttpRequest对象的方法。
/* * 创建XMLHttpRequest对象 * */ function ajaxFunction(){ var xmlHttp; try { // Firefox, Opera 8.0+, Safari xmlHttp = new XMLHttpRequest(); } catch (e) { // Internet Explorer try { xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) { alert("您的浏览器不支持AJAX!"); return false; } } } return xmlHttp; }
var xmlHttp = ajaxFunction();
/* readyState 属性存有服务器响应的状态信息。每当 readyState 改变时,onreadystatechange 函数就会被执行。*/ xmlHttp.onreadystatechange = function(){ if(xmlHttp.readyState==4){ var data=xmlHttp.responseText; alert("xmlHttp.responseText:"+data); } }
/* * bstrMethod: http方法,例如:POST、GET、PUT及PROPFIND。大小写不敏感。 * bstrUrl: 请求的URL地址,可以为绝对地址也可以为相对地址。 * varAsync[可选]:布尔型,指定此请求是否为异步方式,默认为true。如果为真,当状态改变时会调用onreadystatechange属性指定的回调函数。 * bstrUser[可选]:如果服务器需要验证,此处指定用户名,如果未指定,当服务器需要验证时,会弹出验证窗口。 * bstrPassword[可选]:验证信息中的密码部分,如果用户名为空,则此值将被忽略。 */ xmlHttp.open(bstrMethod, bstrUrl, varAsync, bstrUser, bstrPassword);
/* varBody:欲通过此请求发送的数据。 */ xmlHttp.send(varBody);
原文:http://blog.csdn.net/user_longling/article/details/38518671