您好,欢迎访问三七文档
—高级软件人才实作培训专家!北京传智播客教育讲师:冯威—高级软件人才实作培训专家!北京传智播客教育同步交互和异步交互举个例子:普通B/S模式(同步)AJAX技术(异步)*同步:提交请求-等待服务器处理-处理完毕返回这个期间客户端浏览器不能干任何事*异步:请求通过事件触发-服务器处理(这时浏览器仍然可以作其他事情)-处理完毕同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式。异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式易懂的理解:异步传输:你传输吧,我去做我的事了,传输完了告诉我一声同步传输:你现在传输,我要亲眼看你传输完成,才去做别的事—高级软件人才实作培训专家!北京传智播客教育Ajax的技术的产生•Ajax被认为是(AsynchronousJavaScriptandXML的缩写)。现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax.—高级软件人才实作培训专家!北京传智播客教育—高级软件人才实作培训专家!北京传智播客教育—高级软件人才实作培训专家!北京传智播客教育Ajax:一种不用刷新整个页面便可与服务器通讯的办法图1Web的传统模型。客户端向服务器发送一个请求,服务器返回整个页面,如此反复图2在Ajax模型中,数据在客户端与服务器之间独立传输。服务器不再返回整个页面—高级软件人才实作培训专家!北京传智播客教育不用刷新整个页面便可与服务器通讯的办法:•Flash•Javaapplet•框架:如果使用一组框架构造了一个网页,可以只更新其中一个框架,而不必惊动整个页面•隐藏的iframe•XMLHttpRequest:该对象是对JavaScript的一个扩展,可使网页与服务器进行通信。是创建Ajax应用的最佳选择。实际上通常把Ajax当成XMLHttpRequest对象的代名词—高级软件人才实作培训专家!北京传智播客教育的工作原理Ajax的核心是JavaScript对象XmlHttpRequest。该对象在InternetExplorer5中首次引入,它是一种支持异步请求的技术。简而言之,XmlHttpRequest使您可以使用JavaScript向服务器提出请求并处理响应,而不阻塞用户。—高级软件人才实作培训专家!北京传智播客教育的工作原理AJAX采用异步交互过程。AJAX在用户与服务器之间引入一个中间媒介,从而消除了网络交互过程中的处理—等待—处理—等待缺点。用户的浏览器在执行任务时即装载了AJAX引擎。AJAX引擎用JavaScript语言编写,通常藏在一个隐藏的框架中。它负责编译用户界面及与服务器之间的交互。AJAX引擎允许用户与应用软件之间的交互过程异步进行,独立于用户与网络服务器间的交流。现在,可以用Javascript调用AJAX引擎来代替产生一个HTTP的用户动作,内存中的数据编辑、页面导航、数据校验这些不需要重新载入整个页面的需求可以交给AJAX来执行。使用AJAX,可以为JSP、开发人员、终端用户带来可见的便捷:用户界面AJAX引擎服务器用户界面服务器—高级软件人才实作培训专家!北京传智播客教育(AsynchronousJavaScriptandXML)并不是一项新技术,其实是多种技术的综合,包括Javascript、XHTML和CSS、DOM、XML和XMLHttpRequest.•服务器端语言:服务器需要具备向浏览器发送特定信息的能力。Ajax与服务器端语言无关。•XML(eXtensibleMarkupLanguage,可扩展标记语言)是一种描述数据的格式。AJAX程序需要某种格式化的格式来在服务器和客户端之间传递信息,XML是其中的一种选择•XHTML(eXtendedHypertextMarkupLanguage,使用扩展超媒体标记语言)和CSS(CascadingStyleSheet,级联样式单)标准化呈现;•DOM(DocumentObjectModel,文档对象模型)实现动态显示和交互;•使用XMLHTTP组件XMLHttpRequest对象进行异步数据读取•使用JavaScript绑定和处理所有数据—高级软件人才实作培训专家!北京传智播客教育不是完美的技术。也存在缺陷:1AJAX大量使用了Javascript和AJAX引擎,而这个取决于浏览器的支持。IE5.0及以上、Mozilla1.0、NetScape7及以上版本才支持,Mozilla虽然也支持AJAX,但是提供XMLHttpRequest的方式不一样。所以,使用AJAX的程序必须测试针对各个浏览器的兼容性。2AJAX更新页面内容的时候并没有刷新整个页面,因此,网页的后退功能是失效的;有的用户还经常搞不清楚现在的数据是旧的还是已经更新过的。这个就需要在明显位置提醒用户“数据已更新”。3对流媒体的支持没有FLASH、JavaApplet好。4一些手持设备(如手机、PDA等)现在还不能很好的支持Ajax。—高级软件人才实作培训专家!北京传智播客教育对象XMLHttpRequest对象XMLHttpRequest是XMLHTTP组件的对象,通过这个对象,AJAX可以像桌面应用程序一样只同服务器进行数据层面的交换,而不用每次都刷新界面,也不用每次将数据处理的工作都交给服务器来做;这样既减轻了服务器负担又加快了响应速度、缩短了用户等待的时间。XMLHttpRequest最早是在IE5中以ActiveX组件的形式实现的。非W3C标准.创建XMLHttpRequest对象(由于非标准所以实现方法不统一)•InternetExplorer把XMLHttpRequest实现为一个ActiveX对象•其他浏览器(Firefox、Safari、Opera…)把它实现为一个本地的JavaScript对象。•XMLHttpRequest在不同浏览器上的实现是兼容的,所以可以用同样的方式访问XMLHttpRequest实例的属性和方法,而不论这个实例创建的方法是什么。—高级软件人才实作培训专家!北京传智播客教育(){varxmlHttp;try{//Firefox,Opera8.0+,SafarixmlHttp=newXMLHttpRequest();}catch(e){try{//InternetExplorerxmlHttp=newActiveXObject(Msxml2.XMLHTTP);}catch(e){try{xmlHttp=newActiveXObject(Microsoft.XMLHTTP);}catch(e){}}}returnxmlHttp;}—高级软件人才实作培训专家!北京传智播客教育()停止当前请求getAllResponseHeaders()把http请求的所有响应首部作为键/值对返回getResponseHeader(headerLabel)返回指定首部的串值open(“method”,”url”)建立对服务器的调用,method参数可以是GET,POST。url参数可以是相对URL或绝对URL。这个方法还包括3个可选参数。send(content)向服务器发送请求setRequestHeader(label,value)把指定首部设置为所提供的值。在设置任何首部之前必须先调用open()—高级软件人才实作培训专家!北京传智播客教育对象属性—高级软件人才实作培训专家!北京传智播客教育发送请求--方法和属性介绍利用XMLHttpRequest实例与服务器进行通信包含以下3个关键部分:•onreadystatechange事件处理函数•open方法•send方法—高级软件人才实作培训专家!北京传智播客教育发送请求--方法和属性介绍onreadystatechange:•该事件处理函数由服务器触发,而不是用户•在Ajax执行过程中,服务器会通知客户端当前的通信状态。这依靠更新XMLHttpRequest对象的readyState来实现。改变readyState属性是服务器对客户端连接操作的一种方式。•每次readyState属性的改变都会触发readystatechange事件—高级软件人才实作培训专家!北京传智播客教育发送请求--方法和属性介绍open(method,url,asynch)•XMLHttpRequest对象的open方法允许程序员用一个Ajax调用向服务器发送请求。•method:请求类型,类似“GET”或”POST”的字符串。若只想从服务器检索一个文件,而不需要发送任何数据,使用GET(可以在GET请求里通过附加在URL上的查询字符串来发送数据,不过数据大小限制为2000个字符)。若需要向服务器发送数据,用POST。•在某些情况下,有些浏览器会把多个XMLHttpRequest请求的结果缓存在同一个URL。如果对每个请求的响应不同,这就会带来不好的结果。把当前时间戳追加到URL的最后,就能确保URL的惟一性,从而避免浏览器缓存结果。•url:路径字符串,指向你所请求的服务器上的那个文件。可以是绝对路径或相对路径。•asynch:表示请求是否要异步传输,默认值为true(异步)。指定true,在读取后面的脚本之前,不需要等待服务器的相应。指定false,当脚本处理过程经过这点时,会停下来,一直等到Ajax请求执行完毕再继续执行。varurl=GetAndPostExample?timeStamp=+newDate().getTime();—高级软件人才实作培训专家!北京传智播客教育发送请求--方法和属性介绍send(data):•open方法定义了Ajax请求的一些细节。send方法可为已经待命的请求发送指令•data:将要传递给服务器的字符串。•若选用的是GET请求,则不会发送任何数据,给send方法传递null即可:request.send(null);•当向send()方法提供参数时,要确保open()中指定的方法是POST,如果没有数据作为请求体的一部分发送,则使用null.•完整的Ajax的GET请求示例:使用get请求时send方法参数时null,如果传值的话,服务器也接受不到—高级软件人才实作培训专家!北京传智播客教育发送请求--方法和属性介绍setRequestHeader(header,value)•当浏览器向服务器请求页面时,它会伴随这个请求发送一组首部信息。这些首部信息是一系列描述请求的元数据(metadata)。首部信息用来声明一个请求是GET还是POST。•Ajax请求中,发送首部信息的工作可以由setRequestHeader完成•参数header:首部的名字;参数value:首部的值。•如果用POST请求向服务器发送数据,需要将“Content-type”的首部设置为“application/x-
本文标题:ajax课件冯威
链接地址:https://www.777doc.com/doc-2896820 .html