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()是相对比较复杂的一段代码,特别当你不能熟悉阅读JavaS
cript时。折中方案是在你的JavaScript库中包含此函数,你可以简单地处理Ajax服务器
响应,而不用去注意XMLHttpRequest的内部细节。重要是你自己要理解在代码中如何使
用getReadyStateHandler()。
在列表3中,你看到getReadyStateHandler()被这样调用:
handlerFunction=
getReadyStateHandler(req,updateCart)
由它返回的函数将会检查在req变量中的XMLHttpRequest是否已完成,并调用由upda
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("total");
}
到现在,关于Ajax处理过程的教程已经结束,也许你想让应用运行起来,并看看它
的实际运作。这个例子非常简单,有非常大的改进的余地。比如,我在服务器端代码中
包含了从购物车中移除条目的代码,但从客户端UI中没有访问的途径。作为一个练习,
尝试在现有的JavaScript基础上实际这个功能。
|