枫林在线论坛精华区>>技术交流
[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基础上实际这个功能。

========== * * * * * ==========
返回