ajax简易教程2(转载)

本文介绍了一种使用Ajax技术实现购物车动态更新的方法。通过发送异步请求至服务器端Servlet,可实现在不刷新页面的情况下更新购物车商品。服务器端处理请求后,返回XML格式的数据,客户端JavaScript再解析这些数据并更新页面。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Servlet请求处理
*
* 通过产品编码,在购物车中添加一个条目
* itemCode – 需要添加条目的产品编码
*/
function addToCart(itemCode)
{
  
// 获取一个XMLHttpRequest实例
   var req = newXMLHttpRequest();
  
// 设置用来从请求对象接收回调通知的句柄函数
   var handlerFunction = getReadyStateHandler(req, updateCart);
   req.onreadystatechange
= handlerFunction;
  
// 打开一个联接到购物车servlet的HTTP POST联接
  
// 第三个参数表示请求是异步的
   req.open("POST", "cart.do", true);
  
// 指示请求体包含form数据
   req.setRequestHeader("Content-Type",
                       
"application/x-www-form-urlencoded");
  
// 发送标志需要添加到购物车中条目的form-encoded数据
   req.send("action=add&item="+itemCode);
}

 

      通过一个servlet来处理XMLHttpRequest与处理一个来自浏览器的普通的HTTP请求基本上相似。可以通过调用HttpServletRequest.getParameter()来获取由POST请求体传送过来的form-encoded数据。Ajax请求也与普通的WEB请求样都成为此应用同一HttpSession会话进程的一部分。这对于购物车例子来说很有肜,因为我们可以通过会话将多个请求的状态都保存到同一个JavaBean购物车对象中,并可以序列化。

      列表4是处理Ajax请求并更新购物车的简单servlet的代码片断。从用户会话中检索出一个Cart Bean,并按请求的参数更新它。之后Cart Bean被序列化到XML,并被写回ServletRespone。注意,一定要将响应内容的类型设置为application/xml,否则,XMLHttpRequest将不能将响应内容解析为一个XML DOM。

      列表4:处理Ajax请求的Servlet代码

public void doPost(HttpServletRequest req, HttpServletResponse res)
                        
throws java.io.IOException {
   Cart cart
= getCartFromSession(req);
   String action
= req.getParameter("action");
   String item
= req.getParameter("item");
  
if ((action != null)&&(item != null)) {
    
// 在购物车中添加或移除一个条目
    if ("add".equals(action)) {
       cart.addItem(item);
     }
else if ("remove".equals(action)) {
       cart.removeItems(item);
     }

   }

  
// 将购物车状态序列化到XML
   String cartXml = cart.toXml();
  
// 将XML写入response.
   res.setContentType("application/xml");
   res.getWriter().write(cartXml);
}


 

      列表5展示了由Cart.toXml()方法生成的XML。注意到生成的cart元素的属性,是一个通过System.currentTimeMillis()生成的时间戳。

      列表5:Cart对象序列化得到的XML

<?xml version="1.0"?>
<cart generated="1123969988414" total="$171.95">
  
<item code="hat001">
    
<name>Hat</name>
    
<quantity>2</quantity>
  
</item>
  
<item code="cha001">
    
<name>Chair</name>
    
<quantity>1</quantity>
  
</item>
  
<item code="dog001">
    
<name>Dog</name>
    
<quantity>1</quantity>
  
</item>
</cart>

 

      如果你观察一下下载站点提供的例子应用源码中的Cart.java,你将会看到它通过简单地追加字符串来生成XML。对于本例子来说,它已经足够了,我将会在本系统文章的以后一期中介绍一些更好的方法。

      现在你知道了CartServlet如何响应一个XMLHttpRequest。下一步是返回到客户端,如何用服务器响应来更新页面状态。

     通过JavaScript来处理服务器响应

      XMLHttpRequest的readyState属性是一个给出请求生命周期状态的数字值。它从表示“未初始化”的0变化到表示“完成”的4。每次readyState改变时,都会引发readystatechange事件,通过onreadystatechange属性配置回调处理函数将会被调用。

      在列表3中,你已看到通过调用函数getReadyStateHandler()创建了一个处理函数,并被配置给onreadystatechange属性。getReadyStateHandler()使用了这样的事实:函数是JavaScript中的主要对象。这意味着,函数可以作为参数被传递到其它函数,并且可以创建并返回其它函数。getReadystateHandler()要做是就是返回一个函数,来检查XMLHttpRequet是否已经完成处理,并传递XML服务器响应到由调用者指定的处理函数。列表6是getReadyStateHandler()的代码。

     

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值