`

ajax简易教程3(转载)

阅读更多
列表6:函数getReadyStateHandler()
/**//*
* Returns a function that waits for the specified XMLHttpRequest
* to complete, then passes its XML response to the given handler function.
* req - The XMLHttpRequest whose state is changing
* responseXmlHandler - Function to pass the XML response to
*/

function getReadyStateHandler(req, responseXmlHandler)
{
  
// 返回一个监听XMLHttpRequest实例的匿名函数
  return function () {
    
// 如果请求的状态是“完成”
    if (req.readyState == 4) {
      
// 检查是否成功接收了服务器响应
      if (req.status == 200) {
        
// 将载有响应信息的XML传递到处理函数
         responseXmlHandler(req.responseXML);
       }
else {
        
// 有HTTP问题发生
         alert("HTTP error: "+req.status);
       }

     }

   }

}


 

       HTTP状态码

      在列表6中,XMLHttpRequest的status属性被测试用来确定请求是否成功完成。当处理简单的GET与POST请求,你可以认为只要不是200(OK)的状态就表示发生了错误。若服务器发送了一个重定向响应(例如,301或302),浏览器会透明地完成重定向并从新位置获取相应的资源;XMLHttpRequest不会看到重定向状态码。同时,浏览器自动添加一个缓存控制:对于所有XMLHttpRequest都使用no-cache header,这样客户端代码就可以不用处理304(not-modified)响应。

      关于getReadyStateHandler()

      getReadyStateHandler()是相对比较复杂的一段代码,特别当你不能熟悉阅读JavaScript时。折中方案是在你的JavaScript库中包含此函数,你可以简单地处理Ajax服务器响应,而不用去注意XMLHttpRequest的内部细节。重要是你自己要理解在代码中如何使用getReadyStateHandler()。

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

handlerFunction=getReadyStateHandler(req,updateCart)。

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

     提取购物车数据

      列表7中展示了updateCart()中的代码。此函数使用DOM来解析购物车XML文档,并更新WEB页面(参见列表1)来反映新的购物车内容。注意对用来提取数据的XML DOM的调用。Cart元素上生成的属性,即序列化时生成的时间戳,通过检测它可以保证不会用老的数据来覆盖新的购物车数据。Ajax请求天生就是异步的,通过这个检测可以有效避免在过程外到达的服务器响应的干扰。

      列表7:更新页面来反映出购物车XML文档内容

function updateCart(cartXML) {
// 从文档中获取根元素“cart”
var cart = cartXML.getElementsByTagName("cart")[0];
// 保证此文档是最新的
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[I];
     
// 从name与quantity元素中提取文本节点
      var name = item.getElementsByTagName("name")[0].firstChild.nodeValue;
      var quantity
= item.getElementsByTagName("quantity")[0].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基础上实际这个功能。

     。 使用Ajax的挑战

 

分享到:
评论

相关推荐

    AJAX简易教程及实例

    **AJAX简易教程及实例详解** AJAX(Asynchronous JavaScript and XML)是一种在不刷新整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使网页实现异步更新,提升了用户体验。...

    Ajax简易在线聊天室

    **Ajax简易在线聊天室** Ajax(Asynchronous JavaScript and XML)技术是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这个"Ajax简易在线聊天室"项目是一个很好的学习实例,它将帮助我们深入理解...

    ajax 基础教程源代码

    ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础教程源代码ajax 基础...

    ajax视频教程

    在本“Ajax视频教程”中,你将学习如何有效地使用Ajax提升用户体验,实现网页的无刷新更新。 首先,了解Ajax的工作原理至关重要。它通过创建XMLHttpRequest对象(通常简称为XHR)来实现与服务器的通信。当用户触发...

    AJAX 简易学习教程

    AJAX(Asynchronous JavaScript and XML)是一种在无需刷新整个页面的情况下,能够更新部分网页技术。它的核心在于XMLHttpRequest对象,这个对象被所有现代浏览器支持,包括IE5和IE6(在旧版本中通过ActiveXObject...

    Ajax简易聊天室,ASP+Ajax简易聊天室

    Ajax简易聊天室,运行于ASP环境,用Access存储聊天记录,本程序纯属为了学习,请不要当成功能强大的聊天室来用,呵呵,只是想研究一下Ajax练手的,实现了聊天室的基本雏形,可以无刷新发送消息,数据库定时更新,...

    ajax 基础教程

    ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax 基础教程ajax ...

    W3School Ajax教程

    W3School Ajax教程 Ajax 教程 整理的W3School Ajax教程

    ajax教程

    **Ajax 教程** Ajax(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使得网页实现异步更新,提高了用户体验,尤其是在数据...

    完全手册:ASP.net.Ajax电子教程

    **ASP.NET AJAX 全面解析** ASP.NET AJAX(Asynchronous JavaScript and XML)是微软为.NET Framework提供的一种技术,...通过深入学习《完全手册:ASP.NET AJAX电子教程》,你可以掌握这一技术,提升Web开发能力。

    Ajax简易学习教程

    课件,学习用 课件,学习用 课件,学习用 课件,学习用课件,学习用

    ajax视频教程1

    本视频教程将深入讲解Ajax的核心概念、工作原理以及实际应用,旨在帮助学习者掌握这一强大的Web开发工具。** ### 1. Ajax核心概念 Ajax的核心在于创建XMLHttpRequest对象,它是JavaScript的一个内置对象,用于在...

    Ajax简易博客网站

    **Ajax简易博客网站** 在网页开发中,Ajax(Asynchronous JavaScript and XML)技术是一种用于创建快速、动态网页的重要方法。它允许网页在不重新加载整个页面的情况下与服务器交换数据并更新部分网页内容,提升了...

    ajax基础教程3

    ajax基础教程3 中文需要 下载四个文件再解压 (由于该资料有三十几m )(也就是还需要下载其它三个文件) Ajax基础教程1 Ajax基础教程2 Ajax基础教程3 Ajax基础教程4

    ajax中文简易教程

    **Ajax(Asynchronous JavaScript and XML)**是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。这个技术由jQuery、Prototype等库广泛采用,使得Web应用能够更快速地响应用户交互,提升用户体验。Ajax的...

    Jquery Ajax简易计算器

    **jQuery AJAX简易计算器** 在Web开发中,动态交互是提升用户体验的重要手段,而jQuery的AJAX功能正是实现这种交互的核心技术。本项目“jQuery AJAX简易计算器”旨在展示如何利用jQuery库与服务器端进行异步数据...

    Ajax基础教程(扫描版)

    原书名:Foundations of Ajax 原出版社: Apress 作者: (美)Ryan Asleson,Nathaniel T.Schutta 译者: 金灵 等 丛书名: 图灵程序设计丛书 出版社:人民邮电出版社 ISBN:7115144818 上架时间:2006-2-14 ...

Global site tag (gtag.js) - Google Analytics