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

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

【2005-11-03 11:17】【】【赛迪网】

  发送一个XMLHttpRequest

  我将从Ajax时序图的起点开始:从浏览器创建并发送一个XMLHttpRequest。不幸的是

,在不同的浏览器中创建XMLHttpRequest的方法都不一样。列表2中示例的JavaScript函

数消除了这些与浏览器种类相关的问题,正确检测与当前浏览器相关的方法,并返回一

个可以使用的XMLHttpRequest。最好将它看成备用代码,将它简单拷贝到你的JavaScri
p
t库中,在需要一个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;
}

  稍后,我将讨论如何对待不支持XMLHttpReauest的浏览器的一些技巧。现在,列表
2
中展示的示例函数将总是可以返回一个XMLHttpReauest实例。

  回到购物车例子的场景中,只要用户针对某一个目录条目点击了Add to Cart按钮,

我就要调用一个Ajax交互。名为addToCart()的onclick函数通过Ajax调用(如列表1中所

示)来负责更新购物车的状态。

  在列表3中,addToCart()要做的第一件事就是通过调用newXMLHttpReauest函数(如

列表2中所示)来获取一个XMLHttpRequest的实例,并且注册一个回调函数来接受服务器

响应(我将在稍后详细解释,请参见列表6)。

  因为,此请求将会修改服务器状态,我将使用一个HTTP POST来处理它。通过POST传

送数据需要三个步骤:首先,我需要打开一个到进行通讯的服务器资源的POST连接—在现

在例子中是一个URL映射为cart.do的服务器端servlet。

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

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

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