枫林在线论坛>>技术交流 [管理模式] [快速回复] [推荐给朋友]
[382556] 主题: Ajax铺设了更好的开发Web应用的道路(5)
作者: leaflet 标题:  Ajax铺设了更好的开发Web应用的道路(5)[转载]
昵称: Leaflet 来自: 192.168.*.* 详细
经验值: 105868 发贴时间: 2005年12月17日 11:16:21
等级: ★★★★★ 长度: 2901字
http://searchwebservices.techtarget.com.cn/tips/212/2179212_4.shtml 

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()是相对比较复杂的一段代码,特别当你不能熟悉阅读Java
S
cript时。折中方案是在你的JavaScript库中包含此函数,你可以简单地处理Ajax服务器

响应,而不用去注意XMLHttpRequest的内部细节。重要是你自己要理解在代码中如何使

用getReadyStateHandler()。

  在列表3中,你看到getReadyStateHandler()被这样调用:

handlerFunction=
getReadyStateHandler(req,updateCart)

  由它返回的函数将会检查在req变量中的XMLHttpRequest是否已完成,并调用由upd
a
teCart指定的回调方法处理响应XML。

  提取购物车数据

  列表7中展示了updateCart()中的代码。此函数使用DOM来解析购物车XML文档,并更

新WEB页面(参见列表1)来反映新的购物车内容。注意对用来提取数据的XML 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.getAttribute(&q
uot;total");
}

  到现在,关于Ajax处理过程的教程已经结束,也许你想让应用运行起来,并看看它

的实际运作。这个例子非常简单,有非常大的改进的余地。比如,我在服务器端代码中

包含了从购物车中移除条目的代码,但从客户端UI中没有访问的途径。作为一个练习,

尝试在现有的JavaScript基础上实际这个功能。

========== * * * * * ==========
Top

| 用户注册 | 在线用户 | 投票中心 | 常见问题 |

Copyright © 2001-2012 枫林在线(www.FengLin.info) All Rights Reserved
页面运行使用33.19毫秒