Ajax铺设了更好的开发Web应用道路

2016-02-19 14:13 4 1 收藏

今天图老师小编给大家介绍下Ajax铺设了更好的开发Web应用道路,平时喜欢Ajax铺设了更好的开发Web应用道路的朋友赶紧收藏起来吧!记得点赞哦~

【 tulaoshi.com - Web开发 】


  页面重载提出了一个在Web应用开发中最大的可用性障碍,对于Java开发来说也是一个重大的挑战。在本文中,作者Philip McCarthy介绍了通过后台通道的方法来创建动态Web应用的经验。
  
  Ajax(Asynchronous JavaScript and XML)是一个结合了Java技术、XML、以及JavaScript的编程技术,可以让你构建基于Java技术的Web应用,并打破了使用页面重载的惯例。
  
  Ajax,异步JavaScript与XML,是使用客户端脚本与Web服务器交换数据的Web应用开发方法。这样,Web页面不用打断交互流程进行重新加裁,就可以动态地更新。使用Ajax,你可以创建接近本地桌面应用的,直接的、高可用的、更丰富的、更动态的Web用户接口界面。
  
  Ajax不是一个技术,它更像是一个模式—标志并描述有用的设计技巧的一种方法。对于刚了解它的许多开发人员来说,它是一种新的感觉,但是实现Ajax的所有组件都已存在了许多年。
  
  当前的热闹是因为在2004与2005年出现了一些基于Ajax的非常动态的WebUI,尤其是Google的GMail与Maps应用系统、与照片共享网站Flickr。这些UI充分地使用了后台通道,也被一些开发者称为“Web 2.0”,并导致了大家对Ajax应用兴趣的猛涨。
  
  在本系列中,我将给出所有你需要的开发你自己的Ajax应用的工具。在这第一篇文章中,我将解释在Ajax背后的概念,示范为基于Web的应用系统创建一个Ajax接口的基本步骤。我将使用示例代码来示范实现Ajax动态接口的服务器端Java代码与客户端JavaScript脚本。最后,我将指出一些Ajax方法中易犯的错误,以及在创建Ajax应用时应该考虑的广泛范围内的可用性与易访问性方面的问题。
  
  
  
  你可以使用Ajax来加强传统的Web应用,通过消除页面载入来使交互更流畅。为了示范它,我将使用一个简单的,能动态更新加入的物品购物车。结合一个在线商店,这个方法可以不用等待点击后的页面重载,而让我们继续浏览并挑选物品到购物车中。
  
  虽然,本文中的代码针对购物车例子,但其中展示的技术可以用到其它的Ajax应用中。列表1中展示了购物车示例所使用的HTML代码。在整篇文章中,我都将会引用到这些HTML代码。
  
  
  
  一个Ajax交互从一个称为XMLHttpRequest的JavaScript对象开始。如同名字所暗示的,它允许一个客户端脚本来执行HTTP请求,并且将会解析一个XML格式的服务器响应。Ajax处理过程中的第一步是创建一个XMLHttpRequest实例。使用HTTP方法(GET或POST)来处理请求,并将目标URL设置到XMLHttpRequest对象上。
  
  现在,记住Ajax如何首先处于异步处理状态?当你发送HTTP请求,你不希望浏览器挂起并等待服务器的响应,取而代之的是,你希望通过页面继续响应用户的界面交互,并在服务器响应真正到达后处理它们。
  
  要完成它,你可以向XMLHttpRequest注册一个回调函数,并异步地派发XMLHttpRequest请求。控制权马上就被返回到浏览器,当服务器响应到达时,回调函数将会被调用。
  
  在Java Web服务器上,到达的请求与任何其它HttpServletRequest一样。在解析请求参数后,servlet执行必需的应用逻辑,将响应序列化到XML中,并将它写回HttpServletResponse。
  
  回到客户端,注册在XMLHttpRequest上的回调函数现在会被调用来处理由服务器返回的XML文档。最后,通过更新用户界面来响应服务器传输过来数据,使用JavaScript来操纵页面的HTML DOM。图1是Ajax处理过程的一个时序图。
  
 
  图1:Ajax处理过程

  
  现在,你应该对Ajax处理过程有了一个高层视图。我将进入其中的每一步看看更细节的内容。如果你找不到自己的位置时,就回头再看看图1,加—因为Ajax方法的异步本质,所以时序图并不是笔直向前的。
  
  
  
  我将从Ajax时序图的起点开始:从浏览器创建并发送一个XMLHttpRequest。不幸的是,在不同的浏览器中创建XMLHttpRequest的方法都不一样。列表2中示例的JavaScript函数消除了这些与浏览器种类相关的问题,正确检测与当前浏览器相关的方法,并返回一个可以使用的XMLHttpRequest。最好将它看成备用代码,将它简单拷贝到你的JavaScript库中,在需要一个XMLHttpRequest时使用它即可。
  
  列表2:跨浏览器创建一个XMLHttpRequest
  
  /*
  * 返回一个新建的XMLHttpRequest对象,
  若浏览器不支持则失败
  */
  function newXMLHttpRequest()
  {
  var xmlreq = false;
  if (window.XMLHttpRequest)
  {
  // 在非Microsoft浏览器中
  创建XMLHttpRequest对象
  xmlreq = new XMLHttpRequest();
  } else if (window.ActiveXObject)
  {
  //通过MS ActiveX创建XMLHttpRequest
  try {
  // 尝试按新版InternetExplorer方法创建
  xmlreq = new ActiveXObject
  ("Msxml2.XMLHTTP");
  } catch (e1) {
  // 创建请求的ActiveX对象失败
  try {
  // 尝试按老版InternetExplorer方法创建
  xmlreq = new ActiveXObject
  ("Microsoft.XMLHTTP");
  } catch (e2) {
  // 不能通过ActiveX创建XMLHttpRequest
  }
  }
  }
  return xmlreq;
  }
  
  稍后,我将讨论如何对待不支持XM

1234下一页
  /cart>
  
  如果你观察一下下载站点提供的例子应用源码中的Cart.Java,你将会看到它通过简单地追加字符串来生成XML。对于本例子来说,它已经足够了,我将会在本系统文章的以后一期中介绍一些更好的方法。
  
  现在你知道了CartServlet如何响应一个XMLHttpRequest。下一步是返回到客户端,如何用服务器响应来更新页面状态。
  
  
  
  XMLHttpRequest的readyState属性是一个给出请求生命周期状态的数字值。它从表示“未初始化”的0变化到表示“完成”的4。每次readyState改变时,都会引发readystatechange事件,通过onreadystatechange属性配置回调处理函数将会被调用。
  
  在列表3中,你已看到通过调用函数getReadyStateHandler()创建了一个处理函数,并被配置给onreadystatechange属性。getReadyStateHandler()使用了这样的事实:函数是JavaScript中的主要对象。
  
  这意味着,函数可以作为参数被传递到其它函数,并且可以创建并返回其它函数。getReadystateHandler()要做是就是返回一个函数,来检查XMLHttpRequet是否已经完成处理,并传递XML服务器响应到由调用者指定的处理函数。列表6是getReadyStateHandler()的代码。
  
  列表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);
  }
  }
  }
  }
  
  
  
  在列表6中,XMLHttpRequest的status属性被测试用来确定请求是否成功完成。当处理简单的GET与POST请求,你可以认为只要不是200(OK)的状态就表示发生了错误。若服务器发送了一个重定向响应(例如,301或302),浏览器会透明地完成重定向并从新位置获取相应的资源;XMLHttpRequest不会看到重定向状态码。
  
  同时,浏览器自动添加一个缓存控制:对于所有XMLHttpRequest都使用no-cache header,这样客户端代码就可以不用处理304(not-modified)响应。
  
  
  
  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

上一页1234下一页 LHttpReauest的浏览器的一些技巧。现在,列表2中展示的示例函数将总是可以返回一个XMLHttpReauest实例。
  
  回到购物车例子的场景中,只要用户针对某一个目录条目点击了Add to Cart按钮,我就要调用一个Ajax交互。名为addToCart()的onclick函数通过Ajax调用(如列表1中所示)来负责更新购物车的状态。
  
  在列表3中,addToCart()要做的第一件事就是通过调用newXMLHttpReauest函数(如列表2中所示)来获取一个XMLHttpRequest的实例,并且注册一个回调函数来接受服务器响应(我将在稍后详细解释,请参见列表6)。
  
  因为,此请求将会修改服务器状态,我将使用一个HTTP POST来处理它。通过POST传送数据需要三个步骤:首先,我需要打开一个到进行通讯的服务器资源的POST连接—在现在例子中是一个URL映射为cart.do的服务器端servlet。
  
  下一步,设置XMLHttpRequest的头信息,以标志请求的内容为form-encoded。最后,将form-encoded数据作为请求体,并发送此请求。列表3中集中展示了这些步骤。
  
  列表3:发送一个添加到购物车XMLHttpRequest
  
  /*
  * 通过产品编码,在购物车中添加一个条目
  * 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);
  }
  
  结合以上内容,你可以了解到Ajax处理过程的第一部分—就是在客户端创建并发送HTTP请求。下一步是用来处理请求的Java Servlet代码。
  
  
  
  通过一个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>

上一页1234下一页

来源:https://www.tulaoshi.com/n/20160219/1606456.html

延伸阅读
标签: Web开发
在这个关于AJAX系列的第三部分中(相关文章:第一部分、第二部分),我们将学习如何使用AJAX与服务端进行写作以及这些技术如何产生强大的web应用程序。如果你对学习如何构建类似GMail或者Google Maps的web程序感兴趣的话,这是一篇基础的入门(虽然那两个东东会比我们在这篇文章中提及的内容复杂的多)。在这篇文章中,我使用PHP作为服务端...
标签: Web开发
一. 什么是AJAX?   这个名字代表了异步JavaScript+XMLHTTPRequest,并且意味着你可以在基于浏览器的JavaScript和服务器之间建立套接字通讯。其实AJAX并不是一种新技术,而是已经成功地用于现代浏览器中的若干成功技术的可能性组合。所有的AJAX应用程序实现了一种“丰富的”UI——这是通过JavaScript操作HTML文档对象模型并且经...
标签: Web开发
<h1 使用Ajax开发web应用程序</h1 <p 这个页面演示了AJAX技术如何通过动态读取一个远程文件来更新一个网页的内容--不需要任何网页的重新加载。注意:这个例子对于禁止js的用户来说没有效果。</p <p 这个页面将演示如从取回并处理成组的XML数据。被取回的数据将会以表格形式输出到底下。 <a href="#" onclick="ajaxRead('data_2....
标签: Web开发
新增加的内容,首先是两个新变量的声明:“subAry”和“subAryLen”。它们和之前的变量“dataArray”和“dataArrayLen”类似,除了它们指向不同的数组(特别是它们将指向那些“task”元素-当“dataArray”和“dataArrayLen”指向“pet”元素的时候)。 我们也改变了变量“insertData”的初始值-我们增加了一个表格头(<th )给我们的“task...
标签: Web开发
在过去,由于为了获得新数据而不得不重新加载web页面(或者加载其他页面)导致web应用程序发展被限制。虽然有其他方法可用(不加载其他页面),但是这些技术都没有被很好地支持而且有bug成灾的趋向。在过去的几个月里,一个过去并不被广泛支持的技术已经被越来越多的web冲浪者(web surfers??是指浏览器还是浏览者?)所接受,它给了开发者更...

经验教程

245

收藏

57
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部