AJax技术

www.knowsky.com

字号+ 作者:H5之家 来源:H5之家 2015-09-19 19:53 我要评论( )

Ajax学习 1.概念 Ajax是Asynchronous javaScript and xml的缩写,就是异步Javascript与XML。 传统WEB应用中,页面中用户的每一次操作都将触发一次返回Web服务器的HTTP请求,服务器进行相应处理后返回相应的HEML页面。而在Ajax应用中,页面中用户的操作将通过

Ajax学习

1.概念

Ajax是Asynchronous javaScript and xml的缩写,就是异步Javascript与XML。

传统WEB应用中,页面中用户的每一次操作都将触发一次返回Web服务器的HTTP请求,服务器进行相应处理后返回相应的HEML页面。而在Ajax应用中,页面中用户的操作将通过Ajax

引擎与服务器端进行通信,然后将返回结果提交给客户端Ajax引擎,再由Ajax引擎来决定将这些数据插入到页面的指定位置。

所以Ajax最大的特点就是无刷新的更新页面,减轻了服务器的负担。

2.Ajax技术

Ajax是JavaScript、XML、CSS、DOM等多种已有技术的组合。

2.1xmlhttpRequest

Ajax最核心的技术就是XMLHttPRequest,它是一个具有应用程序接口的JavaScript对象,通过它,可以只同服务器进行数据层面的交换,而不用每次都刷新页面。

XMLHttpRequest对象的常用方法及常用属性如下:

2.2JavaScript

在Web页面中添加动态脚本代码的解释性程序语言。

2.3DOM

Document Object Model(文档对象模型),是表示文档和访问、操作构成文档的各种元素(如HTML标记和文本串)的应用程序接口。在Ajax应用中,通过JavaScript操作DOM,可以达到在不刷新页面的情况下实时修改用户界面的目的。

2.4XML

Extensible Markup Language(可扩展的标记语言),提供了用于描述结构化数据的格式。

2.5CSS

层叠样式表,用于页面布局,通过改变文档对象的CSS属性控制页面的外观和行为。

3.传统Ajax的工作流程

3.1发送请求

1)初始化XMLHttpRequest对象

使用XMLHttpRequest之前需要进行初始化,初始化的方法如下:

if(window.XMLHttpRequest){ http_request=new XMLHttpRequest(); //非IE浏览器}else if(window.ActiveObject){ //IE浏览器 try{ http_request=new ActiveObject("Msxml2.XMLHTTP"); } catch(e){ try{ http_request=new ActiveObject("Microsoft.XMLHTTP"); } catch(e){} }}

2)为XMLHttpRequest对象指定一个回调函数,用于对返回结果进行处理。

http_request.onreadystatechange=getResult; //调用回调函数

如果要指定传递的参数,可以应用以下方法:

http_request.onreadystatechange=function(){getResult(param)};

3)创建一个与服务器的连接,在创建时,需要指定发送请求的方式,以及设置是否采用异步方式发送请求

http_request.open("GET", url, true);// http_request.open("POST", url,true);

4)向服务器发送请求。利用send()方法可以实现向服务器发送请求,该方法需要传递一个参数,如果发送的是GET请求,可以将参数设置为null;如果发送的是POST请求,该方法需要通过该参数指定要发送的请求参数。

发送GET请求:

http_request.send(null);

发送POST请求:

http_request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");var param="user="+......;//组合参数http_request.send(param);

3.2处理服务器响应

在指定的回调函数中,首先需要判断服务器的请求状态,保证请求已完成,然后再根据服务器的HTTP状态码,判断服务器对请求的响应是否成功,如果成功,则获取服务器的响应反馈给客户端。XMLHttpRequest对象提供了两个用来访问服务器响应的属性:一个是responseText属性,返回字符串响应;另一个是responseXML属性,返回XML响应。

1)处理字符串响应

function getResult(){ if(http_request.readyState==4){ //判断请求状态 if(http_request.status==200){ //请求成功,开始处理相应 alert(http_request.responseText); //弹出提示对话框显示响应结果 }else{ alert("错误"); } }}

2)处理XML响应

var xmldoc=http_request.responseXML;

解析xmldoc



 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
网友点评
>