版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、using the xmlhttprequest objectnow that weve discussed the history of dynamic web applications and introduced ajax, its time to cover the heart of the matter: how to use the xmlhttprequest object. while ajax is more of a technique than a technology, without widespread support for xmlhttprequest, goo
2、gle suggest and ta-da list wouldnt exist as we currently know them. and you wouldnt be reading this book! xmlhttprequest was originally implemented in internet explorer 5 as an activex component. that it worked only in internet explorer kept most developers from using xmlhttprequest until its recent
3、 adoption as a de facto standard in mozilla 1.0 and safari 1.2. its important to note that xmlhttprequest is not a w3c standard, though much of the functionality is covered in a new proposal: the dom level 3 load and save specification. because it is not a standard, its behavior may differ slightly
4、from browser to browser, though most methods and properties are widely supported. currently, firefox, safari, opera, konqueror, and internet explorer all implement the behavior of the xmlhttprequest object similarly. that said, if a significant number of your users still access your site or applicat
5、ion with older browsers, you will need to consider your options. as we discussed in chapter 1, if you are going to use ajax techniques, you need to either develop an alternative site or allow your application to degrade gracefully. with most usage statistics indicating that only a small fraction of
6、browsers in use today lack xmlhttprequest support, the chances of this being a problem are slim. however, you need to check your web logs and determine what clients your customers are using to access your sites. overview of the xmlhttprequest object you must first create an xmlhttprequest object usi
7、ng javascript before you can use the object to send requests and process responses. since xmlhttprequest is not a w3c standard, you can use javascript in a couple of ways to create an instance of xmlhttprequest. internet explorer implements xmlhttprequest as an activex object, and other browsers suc
8、h as firefox, safari, and opera implement it as a native javascript object. because of these differences, the javascript code must contain logic to create an instance of xmlhttprequest using the activex technique or using the native javascript object technique. the previous statement might send shiv
9、ers down the spines of those who remember the days when the implementation of javascript and the dom varied widely among browsers. fortunately, in this case you dont need elaborate code to identify the browser type to know how to create an instance of the xmlhttprequest object. all you need to do is
10、 check the browsers support of activex objects. if the browser supports activex objects, then you create the xmlhttprequest object using activex. otherwise, you create it using the native javascript object technique. if the call to window.activexobjectfails, then the javascript branches to the elses
11、tatement, which determines whether the browser implements xmlhttprequest as a native javascript object. if window.xmlhttprequestexists, then an instance of xmlhttprequest is created. thanks to javascripts dynamically typed nature and that xmlhttprequest implementations are compatible across various
12、browsers, you can access the properties and methods of an instance of xmlhttprequest identically, regardless of the method used to create the instance. this greatly simplifies the development process and keeps the javascript free of browser-specific logic. methods and properties table 2-1 shows some
13、 typical methods on the xmlhttprequest object. dont worry; well talk about these methods in greater detail in a moment. table 2-1. standard xmlhttprequest operationsmethoddescriptionabort()the current request.getallresponseheaders()returns all the response headers for the http request as key/value p
14、airs.getresponseheader(header)returns the string value of the specified header.open(method, url)sets the stage for a call to the server. the method argument can be either get, post, or put. the url argument can be relative or absolute. this method includes three optional arguments. send(content)send
15、s the request to the server.setrequestheader(header, value)sets the specified header to the supplied value. open() must be called before attempting to set any headers.lets take a closer look at these methods. void open(string method, string url, boolean asynch, string username, string password): thi
16、s method sets up your call to the server. this method is meant to be the script-only method of initializing a request. it has two required arguments and three optional arguments. you are required to supply the specific method you are invoking (get, post, or put) and the url of the resource you are c
17、alling. you may optionally pass a boolean indicating whether this call is meant to be asynchronousthe default is true, which means the request is asynchronous in nature. if you pass a false, processing waits until the response returns from the server. since making calls asynchronously is one of the
18、main benefits of using ajax, setting this parameter to false somewhat defeats the purpose of using the xmlhttprequest object. that said, you may find it useful in certain circumstances such as validating user input before allowing the page to be persisted. the last two parameters are self-explanator
19、y, allowing you to include a specific username and password. void send(content): this method actually makes the request to the server. if the request was declared as asynchronous, this method returns immediately, otherwise it waits until the response is received. the optional argument can be an inst
20、ance of a dom object, an input stream, or a string. the content passed to this method is sent as part of the request body. void setrequestheader(string header, string value): this method sets a value for a given header value in the http request. it takes a string representing the header to set and a
21、 string representing the value to place in the header. note that it must be called after a call to open(). of all these methods, the two you will use the most are open() and send(). the xmlhttprequest object has a number of properties that prove themselves quite useful while designing ajax interacti
22、ons. void abort(): this method is really quite self-explanatoryit stops the request.string getallresponseheaders(): the core functionality of this method should be familiar to web application developersit returns a string containing response headers from the http request. headers include content-len
23、gth, date, and uri.string getresponseheader(string header): this method is a companion to getallresponseheaders() except it takes an argument representing the specific header value you want, returning this value as a string. in addition to these standard methods, the xmlhttprequest object exposes th
24、e properties listed in table 2-2. youll use these properties extensively when working with xmlhttprequest. table 2-2. standard xmlhttprequest properties propertydescriptiononreadystatechangethe event handler that fires at every state change, typically a call to a javascript function.readystatethe st
25、ate of the request. the five possible values are 0 = uninitialized, 1 = loading, 2 = loaded, 3 = interactive, and 4 = complete. responsetextthe response from the server as a string.responsexmlthe response from the server as a string. the response from the server as xml. this object can be parsed and
26、 examined as a dom object.statusthe http status code from the server (that is, 200 for ok, 404 for not found, and so on).statustextthe text version of the http status code (that is, ok or not found, and so on).an example interaction at this point, you might be wondering what a typical ajax interacti
27、on looks like. figure 2-1 server sourceeventdatabaseweb containerajax-enabled web applicationclientserverfigure 2-1. standard ajax interactionunlike the standard request/response approach found in a standard web client, an ajax application does things a little bit differently. 1. a client-side event
28、 triggers an ajax event. any number of things can trigger this, from a simple onchange event to some specific user action. you might have code like this: 2. an instance of the xmlhttprequest object is created. using the open() method, the call is set upthe url is set along with the desired http meth
29、od, typically getor post. the request is actually triggered via a call to the send() method. 3. a request is made to the server. this might be a call to a servlet, a cgi script, or any server-side technique. 4. the server can do anything you can think of, including accessing a data store or even ano
30、ther system. 5. the request is returned to the browser. the content-typeis set to text/xmlthe xmlhttprequest object can process results only of the text/html type. in more complex instances, the response might be quite involved and include javascript, dom manipulation, or other related technologies.
31、 note that you also need to set the headers so that the browser will not cache the results locally. you do this with the following code: response.setheader(cache-control, no-cache);response.setheader(pragma, no-cache); in general, the various frameworks and toolkits available on the web take care of
32、 the basic wiring and the browser abstractions, and some add user interface components. some are purely client based; others require work on the server. many of these frameworks have just begun development or are in the early phases of release; the landscape is constantly changing, with new librarie
33、s and versions coming out regularly. as the field matures, the best ones will become apparent. some of the more mature libraries include libxmlrequest, rslite, sarissa,javascript object notation (json), jsrs, direct web remoting (dwr), and ruby on rails. this is a dynamic space, so keep your rss agg
34、regator tuned to those sites dedicated to posting about all things ajax! summary while ajaxesque techniques have been used for many years, the recent adoption of the xmlhttprequest object by modern browsers has ushered in a new era of developing rich web applications. in this chapter, we established
35、 the basics of working with the heart of ajax, the xmlhttprequest object. at this point, you know the methods and properties of the xmlhttprequest object, and weve shown you some simple examples of their use. as you can see, the object is pretty straightforward and hides much of its complexity from
36、you. combined with a healthy dose of javascript and some basic dom manipulation, ajax allows for a level of interactivity previously unmatched on the web.英文翻译使用xmlhttprequest对象我们已经讨论了动态web应用的发展历史,并简要介绍了ajax,下面再来讨论问题的关键:如何使用xmlhttprequest对象。尽管与其说ajax是一种技术,不如说是一种技巧,但如果没有对xmlhttprequest的广泛支持,google sug
37、gest和ta-da list可能不会像我们看到的有今天这样的发展,而你可能也不会看到手上的这本书!xmlhttprequest最早是在ie 5中以activex组件形式实现的。由于只能在ie中使用,所以大多数开发人员都没有用xmlhttprequest,直到最近,mozilla 1.0和safari 1.2把它采用为事实上的标准,情况才有改观。需要重点说明的是,xmlhttprequest并不是一个w3c标准,不过许多功能已经涵盖在一个新提案中:dom level 3加载和保存规约(dom level 3 load and save specification)。因为它不是标准,所以在不同浏
38、览器上的表现也稍有区别,不过大多数方法和属性都得到了广泛的支持。当前,firefox、safari、opera、konqueror和internet explorer都以类似的方式实现了xmlhttprequest对象的行为。前面已经说过,如果大量用户还是在使用较旧的浏览器访问网站或应用,就要三思了。第1章讨论过,在这种情况下,如果要使用ajax技术,要么需要开发一个候选网站,要么你的应用应当能妥善地降级。大多数使用统计表明,在当前使用的浏览器中只有极少数不支持xmlhttprequest,所以一般情况下不会存在这个问题。不过,还是应该查看web日志,确定你的用户在使用什么样的客户端来访问网站
39、。 xmlhttprequest对象概述在使用xmlhttprequest对象发送请求和处理响应之前,必须先用javascript创建一个xmlhttprequest对象。由于xmlhttprequest不是一个w3c标准,所以可以采用多种方法使用javascript来创建xmlhttprequest的实例。internet explorer把xmlhttprequest实现为一个activex对象,其他浏览器(如firefox、safari和opera)把它实现为一个本地javascript对象。由于存在这些差别,javascript代码中必须包含有关的逻辑,从而使用activex技术或者使
40、用本地javascript对象技术来创建xmlhttprequest的一个实例。很多人可能还记得从前的那段日子,那时不同浏览器上的javascript和dom实现简直千差万别,听了上面这段话之后,这些人可能又会不寒而栗。幸运的是,在这里为了明确该如何创建xmlhttprequest对象的实例,并不需要那么详细地编写代码来区别浏览器类型。你要做的只是检查浏览器是否提供对activex对象的支持。如果浏览器支持activex对象,就可以使用activex来创建xmlhttprequest对象。否则,就要使用本地javascript对象技术来创建。如果window.activexobject调用失败
41、(返回null),javascript就会转到else语句分支,确定浏览器是否把xmlhttprequest实现为一个本地javascript对象。如果存在window. xmlhttprequest,就会创建xmlhttprequest的一个实例。由于javascript具有动态类型特性,而且xmlhttprequest在不同浏览器上的实现是兼容的,所以可以用同样的方式访问xmlhttprequest实例的属性和方法,而不论这个实例创建的方法是什么。这就大大简化了开发过程,而且在javascript中也不必编写特定于浏览器的逻辑。方法和属性表2-1显示了xmlhttprequest对象的一些
42、典型方法。不要担心,稍后就会详细介绍这些方法。表2-1标准xmlhttprequest操作方 法描 述abort()停止当前请求getallresponseheaders()把http请求的所有响应首部作为键/值对返回getresponseheader(header)返回指定首部的串值open(method, url)建立对服务器的调用。method参数可以是get、post或put。url参数可以是相对url或绝对url。这个方法还包括3个可选的参数send(content)向服务器发送请求setrequestheader(header, value)把指定首部设置为所提供的值。在设置任何首
43、部之前必须先调用open()下面来更详细地讨论这些方法。void open(string method, string url, boolean asynch, string username, string password):这个方法会建立对服务器的调用。这是初始化一个请求的纯脚本方法。它有两个必要的参数,还有3个可选参数。要提供调用的特定方法(get、post或put),还要提供所调用资源的url。另外还可以传递一个boolean值,指示这个调用是异步的还是同步的。默认值为true,表示请求本质上是异步的。如果这个参数为false,处理就会等待,直到从服务器返回响应为止。由于异步调用是使
44、用ajax的主要优势之一,所以倘若将这个参数设置为false,从某种程度上讲与使用xmlhttprequest对象的初衷不太相符。不过,前面已经说过,在某些情况下这个参数设置为false也是有用的,比如在持久存储页面之前可以先验证用户的输入。最后两个参数不说自明,允许你指定一个特定的用户名和密码。void send(content):这个方法具体向服务器发出请求。如果请求声明为异步的,这个方法就会立即返回,否则它会等待直到接收到响应为止。可选参数可以是dom对象的实例、输入流,或者串。传入这个方法的内容会作为请求体的一部分发送。void setrequestheader(string head
45、er, string value):这个方法为http请求中一个给定的首部设置值。它有两个参数,第一个串表示要设置的首部,第二个串表示要在首部中放置的值。需要说明,这个方法必须在调用open()之后才能调用。在所有这些方法中,最有可能用到的就是open()和send()。xmlhttprequest对象还有许多属性,在设计ajax交互时这些属性非常有用。void abort():顾名思义,这个方法就是要停止请求。string getallresponseheaders():这个方法的核心功能对web应用开发人员应该很熟悉了,它返回一个串,其中包含http请求的所有响应首部,首部包括conten
46、t-length、date和uri。string getresponseheader(string header):这个方法与getallresponseheaders()是对应的,不过它有一个参数表示你希望得到的指定首部值,并且把这个值作为串返回。除了这些标准方法,xmlhttprequest对象还提供了许多属性,如表2-2所示。处理xmlhttprequest时可以大量使用这些属性。表2-2标准xmlhttprequest属性属 性描 述onreadystatechange每个状态改变时都会触发这个事件处理器,通常会调用一个javascript函数readystate请求的状态。有5个可取
47、值:0 = 未初始化,1 = 正在加载,2 = 已加载,3 = 交互中,4 = 完成responsetext服务器的响应,表示为一个串responsexml服务器的响应,表示为xml。这个对象可以解析为一个dom对象status服务器的http状态码(200对应ok,404对应not found(未找到),等等)statustexthttp状态码的相应文本(ok或not found(未找到)等等) 交互示例看到这里,你可能想知道典型的ajax交互是什么样。图2-1显示了ajax应用中标准的交互模式。不同于标准web客户中所用的标准请求/响应方法,ajax应用的做法稍有差别。1. 一个客户端事件
48、触发一个ajax事件。从简单的onchange事件到某个特定的用户动作,很多这样的事件都可以触发ajax事件。可以有如下的代码:客户服务器数据库事件服务器资源使用ajax的web应用web容器图2-1标准ajax交互2. 创建xmlhttprequest对象的一个实例。使用open()方法建立调用,并设置url以及所希望的http方法(通常是get或post)。请求实际上通过一个send()方法调用触发。3. 向服务器做出请求。可能调用servlet、cgi脚本,或者任何服务器端技术。4. 服务器可以做你想做的事情,包括访问数据库,甚至访问另一个系统。5.请求返回到浏览器。content-ty
49、pe设置为text/xmlxmlhttprequest对象只能处理text/html类型的结果。在另外一些更复杂示例中,响应可能涉及更广,还包括javascript、dom管理以及其他相关的技术。需要说明,你还需要设置另外一些首部,使浏览器不会在本地缓存结果。为此可以使用下面的代码:response.setheader(cache-control, no-cache);response.setheader(pragma, no-cache);通常,web上提供的各种框架和工具包负责基本的连接和浏览器抽象,有些还增加了用户界面组件。有一些纯粹基于客户,还有一些需要在服务器上工作。这些框架中的很多只是刚开始开发,或者还处于发布的早期阶段,随着新的库和新的版本的定期出现,情况还在不断发生变化。这个领域正在日渐成熟,最具优势的将脱颖而出。一些比较成熟的库包括libxmlrequest、rslite、sarissa、javascript对象注解(javascript object notation,json)、
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024版公司承包合同参考范本
- 2025别墅装修工程现场清理与劳务分包合同3篇
- 2025年度文化旅游综合体承包设计工程合同4篇
- 2025年度书房软装承接合同样本12篇
- 非计划性拔管相关知识考核试题
- 2024版特许经营协议:快餐连锁品牌授权
- 2025年农业大棚租赁与农业产业园区建设合同4篇
- 2025年度新型城镇化代付工程款三方协议4篇
- 2025年度合同封面定制与知识产权战略布局合同3篇
- 2025年度水库鱼塘渔业养殖与市场拓展承包合同3篇
- CT设备维保服务售后服务方案
- 重症血液净化血管通路的建立与应用中国专家共识(2023版)
- 儿科课件:急性细菌性脑膜炎
- 柜类家具结构设计课件
- 陶瓷瓷砖企业(陶瓷厂)全套安全生产操作规程
- 煤炭运输安全保障措施提升运输安全保障措施
- JTGT-3833-2018-公路工程机械台班费用定额
- 保安巡逻线路图
- (完整版)聚乙烯课件
- 建筑垃圾资源化综合利用项目可行性实施方案
- 大华基线解码器解码上墙的操作
评论
0/150
提交评论