Ajax基本语法.docx
《Ajax基本语法.docx》由会员分享,可在线阅读,更多相关《Ajax基本语法.docx(11页珍藏版)》请在冰豆网上搜索。
Ajax基本语法
一、什么是Ajax?
答:
AJAX(阿贾克斯)即“AsynchronousJavaScriptandXML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。
ajax的优点
1、最大的一点是页面无刷新,用户的体验非常好。
2、使用异步方式与服务器通信,具有更加迅速的响应能力。
3、可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。
并且减轻服务器的负担,ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,和响应对服务器造成的负担。
4、基于标准化的并被广泛支持的技术,不需要下载插件或者小程序。
ajax的缺点
1、ajax不支持浏览器back按钮。
2、安全问题AJAX暴露了与服务器交互的细节。
3、对搜索引擎的支持比较弱。
4、破坏了程序的异常机制。
5、不容易调试。
二、主要包含的技术
答:
基于web标准(standards-basedpresentation)XHTML+CSS的表示;
使用DOM(DocumentObjectModel)进行动态显示及交互;
使用XML和XSLT进行数据交换及相关操作;
使用XMLHttpRequest进行异步数据查询、检索;
使用JavaScript将所有的东西绑定在一起。
AJAX不是指一种单一的技术,而是有机地利用了一系列相关的技术。
AJAX的应用使用支持以上技术的web浏览器作为运行平台。
这些浏览器目前包括:
Mozilla、Firefox、InternetExplorer、Opera、Konqueror及Safari。
JavaScript
如名字所示,AJAX的概念中最重要而最易被忽视的是它也是一种JavaScript编程语言。
JavaScript是一种粘合剂使AJAX应用的各部分集成在一起。
在大部分时间,JavaScript通常被服务端开发人员认为是一种企业级应用不需要使用的东西应该尽力避免。
这种观点来自以前编写JavaScript代码的经历:
繁杂而又易出错的语言。
类似的,它也被认为将应用逻辑任意地散布在服务端和客户端中,这使得问题很难被发现而且代码很难重用。
在AJAX中JavaScript主要被用来传递用户界面上的数据到服务端并返回结果。
XMLHttpRequest对象用来响应通过HTTP传递的数据,一旦数据返回到客户端就可以立刻使用DOM将数据放到网面上。
XMLHttpRequest
XMLHttpRequest对象在大部分浏览器上已经实现而且拥有一个简单的接口允许数据从客户端传递到服务端,但并不会打断用户当前的操作。
使用XMLHttpRequest传送的数据可以是任何格式,虽然从名字上建议是XML格式的数据。
开发人员应该已经熟悉了许多其他XML相关的技术。
XPath可以访问XML文档中的数据,但理解XMLDOM是必须的。
类似的,XSLT是最简单而快速的从XML数据生成HTML或XML的方式。
许多开发人员已经熟悉Xpath和XSLT,因此AJAX选择XML作为数据交换格式是有意义的。
XSLT可以被用在客户端和服务端,它能够减少大量的用JavaScript编写的应用逻辑。
CSS
为了正确的浏览AJAX应用,CSS是一种AJAX开发人员所需要的重要武器。
CSS提供了从内容中分离应用样式和设计的机制。
虽然CSS在AJAX应用中扮演至关重要的角色,但它也是构建跨浏览器应用的一大阻碍,因为不同的浏览器厂商支持各种不同的CSS级别。
服务器端
但不像在客户端,在服务端AJAX应用还是使用建立在如Java,.Net和PHP语言基础上机制;并没有改变这个领域中的主要方式。
调试与浏览器兼容性问题
调试问题
在实际构建AJAX应用中,你需要的不只是文本编辑器。
既然JavaScript是非编译的,它可以容易地编写和运行在浏览器中。
然而,许多工具提供了有用的扩展如语法高亮和智能完成。
不同的IDE提供了对JavaScript支持的不同等级。
来自JetBrains的IntelliJIDEA是一个用来JavaScript开发的更好的IDE,虽然许多开发人员也喜欢Microsoft’sVisualStudio产品(允诺会在最新的版本中改善对AJAX的支持)。
Eclipse包含了两个免费的JavaScript编辑器插件和一个商业的来自ActiveStat的KomodoIDE。
另一个JavaScript和AJAX开发中的问题是调试困难。
不同的浏览器提供不同的通常是隐藏的运行时错误信息,而JavaScript的缺陷如双重变量赋值(通常是由于缺少数据类型)使得调试更加困难。
在AJAX的开发中,调试就更复杂了,因为其需要标识究竟是客户端还是服务端产生的错误。
在过去,JavaScript调试的方法是删除所有代码然后一行行的增加直到错误出现。
现在,更多开发人员回到为IE准备的MicrosoftScriptDebugger和为Mozilla浏览器准备的Venkman。
浏览器兼容性
JavaScript编程的最大问题来自不同的浏览器对各种技术和标准的支持。
构建一个运行在不同浏览器(如IE和火狐)是一个困难的任务。
因此几种AJAXJavaScript框架或者生成基于服务端逻辑或标记库的JavaScript,或者提供符合跨浏览器AJAX开发的客户端JavaScript库。
一些流行的框架包括:
AJAX.Net,Backbase,Bitkraft,Django,DOJO,DWR,MochiKit,Prototype,Rico,Sajax,Sarissa,andScript.aculo.us.
这些框架给开发人员更多的空间使得他们不需要担心跨浏览器的问题。
虽然这些框架提升了开发人员构建应用的能力,但由于厂商已经开发了更细节的用户界面的打包组件解决方案,因此在AJAX组件市场中需要考虑一些其他因素。
例如提供通用用户界面的组件如组合框和数据栅格的几个厂商,都可以被用来在应用中创建良好的通过类似电子数据表方式来查看和编辑数据的体验。
但这些组件不仅是封装了组件的用户界面而且包括与服务端数据的通讯方式,这些组件通常使用基于标记方式来实现如ASP.Net或JSF控件。
展望
最近IE和火狐之间的浏览器之争变得火热起来,因此AJAX开发人员需要足够敏捷的作出反应。
关键点在一些问题如CSS或XML,虽然各种浏览器形成采用最新标准的不同阵营(如Mozilla拥抱SVG和E4X标准及在最新火狐BETA版本中使用XUL,而微软使用自己的XAML技术)。
所有这些技术代表当前AJAX主流JavaScript和XML的市场方向改变。
总的来说,AJAX开发人员必须尽快地跟进最新的技术并利用高产的工具集。
成功的AJAX开发人员还需要留心他们的使用者以避免将任何问题扩大化。
并且AJAX开发人员还需要持续地创新来创建增强Web应用易用性的新方法。
1问题
JavaScript是客户端脚本语言response是服务器语言XMLHttpRequest对象
在哪里?
浏览器对象
1首先创建xmlhttprequest对象,然后用他的属性、方法、事件去干活
我们如何创建能适合各个浏览器的xmlhttpquest对象那?
创建他的对象语句是固定的吧
在使用XMLHttpRequest对象发送请求和处理响应之前,必须先用JavaScript创建一个XMLHttpRequest对象。
由于XMLHttpRequest不是一个W3C标准,所以可以采用多种方法使用JavaScript来创建XMLHttpRequest的实例。
InternetExplorer把XMLHttpRequest实现为一个ActiveX对象,其他浏览器(如Firefox、Safari和Opera)把它实现为一个本地JavaScript对象。
由于存在这些差别,JavaScript代码中必须包含有关的逻辑,从而使用ActiveX技术或者使用本地JavaScript对象技术来创建XMLHttpRequest的一个实例。
很多人可能还记得从前的那段日子,那时不同浏览器上的JavaScript和DOM实现简直千差万别,听了上面这段话之后,这些人可能又会不寒而栗。
幸运的是,在这里为了明确该如何创建XMLHttpRequest对象的实例,并不需要那么详细地编写代码来区别浏览器类型。
你要做的只是检查浏览器是否提供对ActiveX对象的支持。
如果浏览器支持ActiveX对象,就可以使用ActiveX来创建XMLHttpRequest对象。
否则,就要使用本地JavaScript对象技术来创建。
代码清单2-1展示了编写跨浏览器的JavaScript代码来创建XMLHttpRequest对象实例是多么简单。
代码清单2-1 创建XMLHttpRequest对象的一个实例
varxmlHttp;
functioncreateXMLHttpRequest(){
if(window.ActiveXObject){
xmlHttp=newActiveXObject("Microsoft.XMLHTTP");
}
elseif(window.XMLHttpRequest){
xmlHttp=newXMLHttpRequest();
}
}
可以看到,创建XMLHttpRequest对象相当容易。
首先,要创建一个全局作用域变量xmlHttp来保存这个对象的引用。
createXMLHttpRequest方法完成创建XMLHttpRequest实例的具体工作。
这个方法中只有简单的分支逻辑(选择逻辑)来确定如何创建对象。
对window.ActiveXObject的调用会返回一个对象,也可能返回null,if语句会把调用返回的结果看作是true或false(如果返回对象则为true,返回null则为false),以此指示浏览器是否支持ActiveX控件,相应地得知浏览器是不是InternetExplorer。
如果确实是,则通过实例化ActiveXObject的一个新实例来创建XMLHttpRequest对象,并传入一个串指示要创建何种类型的ActiveX对象。
在这个例子中,为构造函数提供的字符串是Microsoft.XMLHTTP,这说明你想创建XMLHttpRequest的一个实例。
如果window.ActiveXObject调用失败(返回null),JavaScript就会转到else语句分支,确定浏览器是否把XMLHttpRequest实现为一个本地JavaScript对象。
如果存在window.
XMLHttpRequest,就会创建XMLHttpRequest的一个实例。
由于JavaScript具有动态类型特性,而且XMLHttpRequest在不同浏览器上的实现是兼容的,所以可以用同样的方式访问XMLHttpRequest实例的属性和方法,而不论这个实例创建的方法是什么。
这就大大简化了开发过程,而且在JavaScript中也不必编写特定于浏览器的逻辑。
表2-1显示了XMLHttpRequest对象的一些典型方法。
不要担心,稍后就会详细介绍这些方法。
表2-1 标准XMLHttpRequest操作
方 法
描 述
abort()
停止当前请求
getAllResponseHeaders()
把HTTP请求的所有响应首部作为键/值对返回
getResponseHeader("header")
返回指定首部的串值
open("method","url")
建立对服务器的调用。
method参数可以是GET、POST或PUT。
url参数可以是相对URL或绝对URL。
这个方法还包括3个可选的参数
send(content)
向服务器发送请求
setRequestHeader("header","value")
把指定首部设置为所提供的值。
在设置任何首部之前必须先调用open()
下面来更详细地讨论这些方法。
voidopen(stringmethod,stringurl,booleanasynch,stringusername,stringpassword):
这个方法会建立对服务器的调用。
这是初始化一个请求的纯脚本方法。
它有两个必要的参数,还有3个可选参数。
要提供调用的特定方法(GET、POST或PUT),还要提供所调用资源的URL。
另外还可以传递一个Boolean值,指示这个调用是异步的还是同步的。
默认值为true,表示请求本质上是异步的。
如果这个参数为false,处理就会等待,直到从服务器返回响应为止。
由于异步调用是使用Ajax的主要优势之一,所以倘若将这个参数设置为false,从某种程度上讲与使用XMLHttpRequest对象的初衷不太相符。
不过,前面已经说过,在某些情况下这个参数设置为false也是有用的,比如在持久存储页面之前可以先验证用户的输入。
最后两个参数不说自明,允许你指定一个特定的用户名和密码。
voidsend(content):
这个方法具体向服务器发出请求。
如果请求声明为异步的,这个方法就会立即返回,否则它会等待直到接收到响应为止。
可选参数可以是DOM对象的实例、输入流,或者串。
传入这个方法的内容会作为请求体的一部分发送。
voidsetRequestHeader(stringheader,stringvalue):
这个方法为HTTP请求中一个给定的首部设置值。
它有两个参数,第一个串表示要设置的首部,第二个串表示要在首部中放置的值。
需要说明,这个方法必须在调用open()之后才能调用。
在所有这些方法中,最有可能用到的就是open()和send()。
XMLHttpRequest对象还有许多属性,在设计Ajax交互时这些属性非常有用。
voidabort():
顾名思义,这个方法就是要停止请求。
stringgetAllResponseHeaders():
这个方法的核心功能对Web应用开发人员应该很熟悉了,它返回一个串,其中包含HTTP请求的所有响应首部,首部包括Content-
Length、Date和URI。
stringgetResponseHeader(stringheader):
这个方法与getAllResponseHeaders()是对应的,不过它有一个参数表示你希望得到的指定首部值,并且把这个值作为串返回。
除了这些标准方法,XMLHttpRequest对象还提供了许多属性,如表2-2所示。
处理XMLHttpRequest时可以大量使用这些属性。
表2-2 标准XMLHttpRequest属性
属 性
描 述
onreadystatechange
每个状态改变时都会触发这个事件处理器,通常会调用一个JavaScript函数
readyState
请求的状态。
有5个可取值:
0=未初始化,1=正在加载,2=已加载,3=交互中,4=完成
responseText
服务器的响应,表示为一个串
responseXML
服务器的响应,表示为XML。
这个对象可以解析为一个DOM对象
status
服务器的HTTP状态码(200对应OK,404对应NotFound(未找到),等等)
statusText
HTTP状态码的相应文本(OK或NotFound(未找到)等等)
看到这里,你可能想知道典型的Ajax交互是什么样。
图2-1显示了Ajax应用中标准的交互模式。
图2-1 标准Ajax交互
不同于标准Web客户中所用的标准请求/响应方法,Ajax应用的做法稍有差别。
1.一个客户端事件触发一个Ajax事件。
从简单的onchange事件到某个特定的用户动作,很多这样的事件都可以触发Ajax事件。
可以有如下的代码:
2.创建XMLHttpRequest对象的一个实例。
使用open()方法建立调用,并设置URL以及所希望的HTTP方法(通常是GET或POST)。
请求实际上通过一个send()方法调用触发。
可能的代码如下所示:
varxmlHttp;
functionvalidateEmail(){
varemail=document.getElementById("email");
varurl="validate?
email="+escape(email.value);
if(window.ActiveXObject){
xmlHttp=newActiveXObject("Microsoft.XMLHTTP");
}
elseif(window.XMLHttpRequest){
xmlHttp=newXMLHttpRequest();
}
xmlHttp.open("GET",url);
xmlHttp.onreadystatechange=callback;
xmlHttp.send(null);
}
3.向服务器做出请求。
可能调用servlet、CGI脚本,或者任何服务器端技术。
4.服务器可以做你想做的事情,包括访问数据库,甚至访问另一个系统。
5.请求返回到浏览器。
Content-Type设置为text/xml——XMLHttpRequest对象只能处理text/html类型的结果。
在另外一些更复杂示例中,响应可能涉及更广,还包括JavaScript、DOM管理以及其他相关的技术。
需要说明,你还需要设置另外一些首部,使浏览器不会在本地缓存结果。
为此可以使用下面的代码:
response.setHeader("Cache-Control","no-cache");
response.setHeader("Pragma","no-cache");[1]
6.在这个示例中,XMLHttpRequest对象配置为处理返回时要调用callback()函数。
这个函数会检查XMLHttpRequest对象的readyState属性,然后查看服务器返回的状态码。
如果一切正常,callback()函数就会在客户端上做些有意思的工作。
以下就是一个典型的回调方法:
functioncallback(){
if(xmlHttp.readyState==4){
if(xmlHttp.status==200){
//dosomethinginterestinghere
}
}
}
可以看到,这与正常的请求/响应模式有所不同,但对Web开发人员来说,并不是完全陌生的。
显然,在创建和建立XMLHttpRequest对象时还可以做些事情,另外当“回调”函数完成了状态检查之后也可以有所作为。
一般地,你会把这些标准调用包装在一个库中,以便在整个应用中使用,或者可以使用Web上提供的库。
这个领域还很新,但是在开源社区中已经如火如荼地展开了大量的工作。
通常,Web上提供的各种框架和工具包负责基本的连接和浏览器抽象,有些还增加了用户界面组件。
有一些纯粹基于客户,还有一些需要在服务器上工作。
这些框架中的很多只是刚开始开发,或者还处于发布的早期阶段,随着新的库和新的版本的定期出现,情况还在不断发生变化。
这个领域正在日渐成熟,最具优势的将脱颖而出。
一些比较成熟的库包括libXmlRequest、RSLite、sarissa、JavaScript对象注解(JavaScriptObjectNotation,JSON)、JSRS、直接Web远程通信(DirectWebRemoting,DWR)和RailsonRuby。
这个领域日新月异,所以应当适当地配置你的RSS收集器,及时收集有关Ajax的所有网站上的信息!
你可能想了解GET和POST之间有什么区别,并想知道什么时候使用它们。
从理论上讲,如果请求是幂等的就可以使用GET,所谓幂等是指多个请求返回相同的结果。
实际上,相应的服务器方法可能会以某种方式修改状态,所以一般情况下这是不成立的。
这只是一种标准。
更实际的区别在于净荷的大小,在许多情况下,浏览器和服务器会限制URL的长度URL用于向服务器发送数据。
一般来讲,可以使用GET从服务器获取数据;换句话说,要避免使用GET调用改变服务器上的状态。
一般地,当改变服务器上的状态时应当使用POST方法。
不同于GET,需要设置XML-HttpRequest对象的Content-Type首部,如下所示:
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
与GET不同,POST不会限制发送给服务器的净荷的大小,而且POST请求不能保证是幂等的。
你做的大多数请求可能都是GET请求,不过,如果需要,也完全可以使用POST。
我们已经介绍了Ajax,下面来简单谈谈远程脚本。
你可能会想:
“Ajax有什么大不了的?
我早就用IFRAME做过同样的事情。
”实际上,我们自己也曾用过这种方法。
这在以前一般称为远程脚本(remotescripting),很多人认为这只是一种修修补补。
不过,这确实提供了一种能避免页面刷新的机制。
2.5.1 远程脚本概述
基本说来,远程脚本是一种远程过程调用类型。
你可以像正常的Web应用一样与服务器交互,但是不用刷新整个页面。
与Ajax类似,你可以调用任何服务器端技术来接收请求、处理请求并返回一个有意义的结果。
正如在服务器端有很多选择,客户端同样有许多实现远程脚本的选择。
你可以在应用中嵌入Flash动画、Javaapplet,或者ActiveX组件,甚至可以使用XML-RPC,但是这种方法过于复杂,因此除非你使用这种技术很有经验,否则这种方法不太合适。
实现远程脚本的通常做法包括将脚本与一个IFRAME(隐藏或不隐藏)结合,以及由服务器返回JavaScript,然后再在浏览器中运行这个JavaScript。
Microsoft提供了自己的远程脚本解决方案,并聪明地称之为Microsoft远程脚本(MicrosoftRemoteScripting,MSRS)。
采用这种方法,可以像调用本地脚本一样调用服务器脚本。
页面中嵌入Javaapplet,以便与服务器通信,.asp页面用于放置服务器端脚本,并用.htm文件管理客户端的布局摆放。
在Netscape和IE4.0及更高版本中都可以使用Microsoft的这种解决方案,可以同步调用,也可以异步调用。
不过,这种解决方案需要Java,这意味着可能还需要附加的安装例程,而且还需要InternetInformationServices(IIS),因此会限制服务器端的选择。
BrentAshley为远程脚本创建了两个免费的跨平台库。
JSRS是一个客户端JavaScript库,它充分利用DHTML向服务器做远程调用。
相当多的操作系统和浏览器上都能使用JSRS。
如果采用一些常用的、流行的服务器端实现(如PHP、Python和PerlCGI),JSRS一般都能在网站上安装并运行。
Ashley免费提供了JSRS,而且还可以从他的网站(www.ashle