AJAX入门——工作原理
理解同步交互和异步交互
举个例子:普通B/S模式(同步) AJAX技术(异步)
* 同步:
* 异步:
什么是Ajax?Ajax被认为是(Asynchronous JavaScript and XML的缩写)。现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax. Ajax并非一种新的技术,而是几种原有技术的结合体。它由下列技术组合而成:
Ajax的工作原理
AJAX采用异步交互过程。AJAX在用户与服务器之间引入一个中间媒介,从而消除了网络交互过程中的处理—等待—处理—等待缺点。
用户的浏览器在执行任务时即装载了AJAX引擎。AJAX引擎用JavaScript语言编写,通常藏在一个隐藏的框架中。它负责编译用户界面及与服务器之间的交互。 AJAX引擎允许用户与应用软件之间的交互过程异步进行,独立于用户与网络服务器间的交流。现在,可以用Javascript调用AJAX引擎来代替产生一个HTTP的用户动作,内存中的数据编辑、页面导航、数据校验这些不需要重新载入整个页面的需求可以交给AJAX来执行。 AJAX的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。
了解XMLHttpRequestXMLHttpRequest是ajax的核心机制,它是在IE5中首先引入的,是一种支持异步请求的技术。简单的说,也就是javascript可以及时向服务器提出请求和处理响应,而不阻塞用户。达到无刷新的效果。 XMLHttpRequest属性有:
readyState 属性可能的值:
但是,由于各浏览器之间存在差异,所以创建一个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; } AJAX(客户端)开发步骤:
1.创建XMLHttpRequest对象
var xmlHttp = ajaxFunction();
2.接受服务器端的响应
/* readyState 属性存有服务器响应的状态信息。每当 readyState 改变时,onreadystatechange 函数就会被执行。*/ xmlHttp.onreadystatechange = function(){ if(xmlHttp.readyState==4){ var data=xmlHttp.responseText; alert("xmlHttp.responseText:"+data); } }
3.打开和服务器的连接
/* * bstrMethod: http方法,例如:POST、GET、PUT及PROPFIND。大小写不敏感。 * bstrUrl: 请求的URL地址,可以为绝对地址也可以为相对地址。 * varAsync [可选]:布尔型,指定此请求是否为异步方式,默认为true。如果为真,当状态改变时会调用onreadystatechange属性指定的回调函数。 * bstrUser [可选]:如果服务器需要验证,此处指定用户名,如果未指定,当服务器需要验证时,会弹出验证窗口。 * bstrPassword [可选]:验证信息中的密码部分,如果用户名为空,则此值将被忽略。 */ xmlHttp.open(bstrMethod,bstrUrl,varAsync,bstrUser,bstrPassword); //POST方式向服务器发送AJAX请求时要通过设置请求头来指定为application/x-www-form-urlencoded编码类型,代码如下: xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
4.发送请求到http服务器
/* varBody:欲通过此请求发送的数据。 */ xmlHttp.send(varBody); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |