彻底消化 Ajax技术原理深层解析(6)

http://www.sina.com.cn 2008年06月12日 08:34  天极yesky

  处理 Mozilla 和非 Microsoft 浏览器

  如果选择的浏览器不是 Internet Explorer,或者为非 Microsoft 浏览器编写代码,就需要使用不同的代码。事实上就是 清单 1 所示的一行简单代码:

  var xmlHttp = new XMLHttpRequest object;。

  这行简单得多的代码在 Mozilla、Firefox、Safari、Opera 以及基本上所有以任何形式或方式支持 Ajax 的非 Microsoft 浏览器中,创建了XMLHttpRequest对象。

  结合起来

  关键是要支持所有浏览器。谁愿意编写一个只能用于 Internet Explorer 或者非 Microsoft 浏览器的应用程序呢?或者更糟,要编写一个应用程序两次?当然不!因此代码要同时支持 Internet Explorer 和非 Microsoft 浏览器。清单 4 显示了这样的代码。

  清单 4. 以支持多种浏览器的方式创建 XMLHttpRequest 对象

  /* Create a new XMLHttpRequest object to talk to the Web server */

  var xmlHttp = false;

  /*@cc_on @*/

  /*@if (@_jscript_version >= 5)

  try {

  xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");

  } catch (e) {

  try {

  xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");

  } catch (e2) {

  xmlHttp = false;

  }

  }

  @end @*/

  if (!xmlHttp && typeof XMLHttpRequest != 'undefined') {

  xmlHttp = new XMLHttpRequest();

  }

  现在先不管那些注释掉的奇怪符号,如@cc_on,这是特殊的 JavaScript 编译器命令。这段代码的核心分为三步:

  1. 建立一个变量xmlHttp来引用即将创建的XMLHttpRequest对象。

  2. 尝试在 Microsoft 浏览器中创建该对象:

  o 尝试使用Msxml2.XMLHTTP对象创建它。

  o 如果失败,再尝试Microsoft.XMLHTTP对象。

  3. 如果仍然没有建立xmlHttp,则以非 Microsoft 的方式创建该对象。

  最后,xmlHttp应该引用一个有效的XMLHttpRequest对象,无论运行什么样的浏览器。

本文导航:
·AJAX概述
·老技术新技巧
·关于XMLHttpRequest对象
·结合Javascript
·结合DOM
·处理 Mozilla 和非 Microsoft 浏览器
·安全性
·处理响应
·连接web表单

发表评论 _COUNT_条
Powered By Google
不支持Flash
·城市对话改革30年 ·新浪城市同心联动 ·诚招合作伙伴 ·企业邮箱畅通无阻
不支持Flash