首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Ajax >

ajax简易课程1(转载)

2012-11-23 
ajax简易教程1(转载)!-- Table of products from stores catalog, one row per item --thName/th

ajax简易教程1(转载)

<!-- Table of products from store's catalog, one row per item -->
ajax简易课程1(转载)<th>Name</th> <th>Description</th> <th>Price</th> <th></th>
ajax简易课程1(转载)ajax简易课程1(转载)
ajax简易课程1(转载)<tr>
ajax简易课程1(转载)??<!-- Item details -->
ajax简易课程1(转载)??<td>Hat</td> <td>Stylish bowler hat</td> <td>$19.99</td>
ajax简易课程1(转载)??<td>
ajax简易课程1(转载)????<!-- Click button to add item to cart via Ajax request -->
ajax简易课程1(转载)????<button onclick="addToCart('hat001')">Add to Cart</button>
ajax简易课程1(转载)??</td>
ajax简易课程1(转载)</tr>
ajax简易课程1(转载)ajax简易课程1(转载)
ajax简易课程1(转载)<!-- Representation of shopping cart, updated asynchronously -->
ajax简易课程1(转载)<ul id="cart-contents">
ajax简易课程1(转载)??<!-- List-items will be added here for each item in the cart -->
ajax简易课程1(转载)</ul>
ajax简易课程1(转载)<!-- Total cost of items in cart displayed inside span element -->
ajax简易课程1(转载)Total cost: <span id="total">$0.00</span>
ajax简易课程1(转载)
ajax简易课程1(转载)

?


????? Ajax处理过程

????? 一个Ajax交互从一个称为XMLHttpRequest的JavaScript对象开始。如同名字所暗示的,它允许一个客户端脚本来执行HTTP请求,并且将会解析一个XML格式的服务器响应。Ajax处理过程中的第一步是创建一个XMLHttpRequest实例。使用HTTP方法(GET或POST)来处理请求,并将目标URL设置到XMLHttpRequest对象上。

????? 现在,记住Ajax如何首先处于异步处理状态?当你发送HTTP请求,你不希望浏览器挂起并等待服务器的响应,取而代之的是,你希望通过页面继续响应用户的界面交互,并在服务器响应真正到达后处理它们。要完成它,你可以向XMLHttpRequest注册一个回调函数,并异步地派发XMLHttpRequest请求。控制权马上就被返回到浏览器,当服务器响应到达时,回调函数将会被调用。

????? 在Java Web服务器上,到达的请求与任何其它HttpServletRequest一样。在解析请求参数后,servlet执行必需的应用逻辑,将响应序列化到XML中,并将它写回HttpServletResponse。


???? 回到客户端,注册在XMLHttpRequest上的回调函数现在会被调用来处理由服务器返回的XML文档。最后,通过更新用户界面来响应服务器传输过来数据,使用JavaScript来操纵页面的HTML DOM。

????? 现在,你应该对Ajax处理过程有了一个高层视图。我将进入其中的每一步看看更细节的内容。如果你找不到自己的位置时,就回头再看看图1,加—因为Ajax方法的异步本质,所以时序图并不是笔直向前的。

???? 发送一个XMLHttpRequest

????? 我将从Ajax时序图的起点开始:从浏览器创建并发送一个XMLHttpRequest。不幸的是,在不同的浏览器中创建XMLHttpRequest的方法都不一样。列表2中示例的JavaScript函数消除了这些与浏览器种类相关的问题,正确检测与当前浏览器相关的方法,并返回一个可以使用的XMLHttpRequest。最好将它看成备用代码,将它简单拷贝到你的JavaScript库中,在需要一个XMLHttpRequest时使用它即可。

列表2:跨浏览器创建一个XMLHttpRequest

ajax简易课程1(转载)ajax简易课程1(转载)/**//*
ajax简易课程1(转载) * 返回一个新建的XMLHttpRequest对象,若浏览器不支持则失败
ajax简易课程1(转载)*/
ajax简易课程1(转载)ajax简易课程1(转载)function newXMLHttpRequest() ajax简易课程1(转载){
ajax简易课程1(转载)?? var xmlreq = false;
ajax简易课程1(转载)ajax简易课程1(转载)??if (window.XMLHttpRequest) ajax简易课程1(转载){
ajax简易课程1(转载)????// 在非Microsoft浏览器中创建XMLHttpRequest对象
ajax简易课程1(转载)???? xmlreq = new XMLHttpRequest();
ajax简易课程1(转载)ajax简易课程1(转载)?? } else if (window.ActiveXObject) ajax简易课程1(转载){
ajax简易课程1(转载)????//通过MS ActiveX创建XMLHttpRequest
ajax简易课程1(转载)ajax简易课程1(转载)????try ajax简易课程1(转载){
ajax简易课程1(转载)??????// 尝试按新版InternetExplorer方法创建
ajax简易课程1(转载)?????? xmlreq = new ActiveXObject("Msxml2.XMLHTTP");
ajax简易课程1(转载)ajax简易课程1(转载)???? } catch (e1) ajax简易课程1(转载){
ajax简易课程1(转载)??????// 创建请求的ActiveX对象失败
ajax简易课程1(转载)ajax简易课程1(转载)??????try ajax简易课程1(转载){
ajax简易课程1(转载)????????// 尝试按老版InternetExplorer方法创建
ajax简易课程1(转载)???????? xmlreq = new ActiveXObject("Microsoft.XMLHTTP");
ajax简易课程1(转载)ajax简易课程1(转载)?????? } catch (e2) ajax简易课程1(转载){
ajax简易课程1(转载)????????// 不能通过ActiveX创建XMLHttpRequest
ajax简易课程1(转载)?????? }
ajax简易课程1(转载)???? }
ajax简易课程1(转载)?? }
ajax简易课程1(转载)??return xmlreq;
ajax简易课程1(转载)}
ajax简易课程1(转载)
ajax简易课程1(转载)

?

????? 稍后,我将讨论如何对待不支持XMLHttpReauest的浏览器的一些技巧。现在,列表2中展示的示例函数将总是可以返回一个XMLHttpReauest实例。

????? 回到购物车例子的场景中,只要用户针对某一个目录条目点击了Add to Cart按钮,我就要调用一个Ajax交互。名为addToCart()的onclick函数通过Ajax调用(如列表1中所示)来负责更新购物车的状态。在列表3中,addToCart()要做的第一件事就是通过调用newXMLHttpReauest函数(如列表2中所示)来获取一个XMLHttpRequest的实例,并且注册一个回调函数来接受服务器响应(我将在稍后详细解释,请参见列表6)。

????? 因为,此请求将会修改服务器状态,我将使用一个HTTP POST来处理它。通过POST传送数据需要三个步骤:首先,我需要打开一个到进行通讯的服务器资源的POST连接—在现在例子中是一个URL映射为cart.do的服务器端servlet。下一步,设置XMLHttpRequest的头信息,以标志请求的内容为form-encoded。最后,将form-encoded数据作为请求体,并发送此请求。

????? 列表3中集中展示了这些步骤。

????? 列表3:发送一个添加到购物车XMLHttpRequest

/????? 结合以上内容,你可以了解到Ajax处理过程的第一部分—就是在客户端创建并发送HTTP请求。下一步是用来处理请求的Java Servlet代码。

热点排行