枫林在线论坛精华区>>技术交流 |
[382556] 主题: Ajax铺设了更好的开发Web应用的道路(5) |
作者: leaflet (Leaflet) | ||
标题: Ajax铺设了更好的开发Web应用的道路(5)[转载] | ||
来自: 192.168.*.* | ||
发贴时间: 2005年12月17日 11:16:21 | ||
长度: 2901字 | ||
http://searchwebservices.techtarget.com.cn/tips/212/2179212_4.sh tml Ajax铺设了更好的开发Web应用的道路 【2005-11-03 11:17】【】【赛迪网】 HTTP状态码 在列表6中,XMLHttpRequest的status属性被测试用来确定请求是否成 功完成。当处 理简单的GET与POST请求,你可以认为只要不是200(OK)的状态就表示发生 了错误。若服 务器发送了一个重定向响应(例如,301或302),浏览器会透明地完成重定 向并从新位置 获取相应的资源;XMLHttpRequest不会看到重定向状态码。 同时,浏览器自动添加一个缓存控制:对于所有XMLHttpRequest都使用 no-cache header,这样客户端代码就可以不用处理304(not-modified)响应。 关于getReadyStateHandler() getReadyStateHandler()是相对比较复杂的一段代码,特别当你不能 熟悉阅读JavaS cript时。折中方案是在你的JavaScript库中包含此函数,你可以简单地处 理Ajax服务器 响应,而不用去注意XMLHttpRequest的内部细节。重要是你自己要理解在 代码中如何使 用getReadyStateHandler()。 在列表3中,你看到getReadyStateHandler()被这样调用: handlerFunction= getReadyStateHandler(req,updateCart) 由它返回的函数将会检查在req变量中的XMLHttpRequest是否已完成, 并调用由upda teCart指定的回调方法处理响应XML。 提取购物车数据 列表7中展示了updateCart()中的代码。此函数使用DOM来解析购物车 XML文档,并更 新WEB页面(参见列表1)来反映新的购物车内容。注意对用来提取数据的XM L DOM的调用。 Cart元素上生成的属性,即序列化时生成的时间戳,通过检测它可以 保证不会用老 的数据来覆盖新的购物车数据。Ajax请求天生就是异步的,通过这个检测 可以有效避免 在过程外到达的服务器响应的干扰。 列表7:更新页面来反映出购物车XML文档内容 function updateCart(cartXML) { // 从文档中获取根元素“cart” var cart = cartXML.getElementsByTagName("cart"); // 保证此文档是最新的 var generated = cart.getAttribute("generated"); if (generated > lastCartUpdate) { lastCartUpdate = generated; // 清除HTML列表,用来显示购物车内容 var contents = document.getElementById("cart-contents"); contents.innerHTML = ""; // 在购物车内按条目循环 var items = cart.getElementsByTagName("item"); for (var I = 0 ; I < items.length ; I++) { var item = items; // 从name与quantity元素中提取文本节点 var name = item.getElementsByTagName("name") .firstChild.nodeValue; var quantity = item.getElementsByTagName ("quantity").firstChild.nodeValue; // 为条目创建并添加到HTML列表中 var li = document.createElement("li"); li.appendChild (document.createTextNode(name+" x "+quantity)); contents.appendChild(li); } } // 更新购物车的金额累计 document.getElementById("total").innerHTML = cart.get Attribute("total"); } 到现在,关于Ajax处理过程的教程已经结束,也许你想让应用运行起 来,并看看它 的实际运作。这个例子非常简单,有非常大的改进的余地。比如,我在服 务器端代码中 包含了从购物车中移除条目的代码,但从客户端UI中没有访问的途径。作 为一个练习, 尝试在现有的JavaScript基础上实际这个功能。 |
||
========== * * * * * ==========
|
返回 |