AJAX XMLHttpRequest

XMLHttpRequest 对象使 AJAX 成为可能。

XMLHttpRequest

XMLHttpRequest 对象是 AJAX 的关键。

该对象在 Internet Explorer 5.5 与 2000 年 7 月发布之后就已经可用了,但是在 2005 年人们开始讨论 AJAX 和 Web 2.0 之前,这个对象并没有得到充分的认识。

创建 XMLHttpRequest 对象

不同的浏览器使用不同的方法来创建 XMLHttpRequest 对象。

Internet Explorer 使用 ActiveXObject.

其他浏览器使用名为 XMLHttpRequest 的 JavaScript 内建对象。

要克服这个问题,可以使用这段简单的代码:

var XMLHttp=null
if (window.XMLHttpRequest)
  {
  XMLHttp=new XMLHttpRequest()
  }
else if (window.ActiveXObject)
  {
  XMLHttp=new ActiveXObject("Microsoft.XMLHTTP")
  }

Pengertian kod:

  1. 首先创建一个作为 XMLHttpRequest 对象使用的 XMLHttp Variabel. Set nilai kepada null.
  2. 然后测试 window.XMLHttpRequest 对象是否可用。在新版本的 Firefox, Mozilla, Opera 以及 Safari 浏览器中,该对象是可用的。
  3. 如果可用,则用它创建一个新对象:XMLHttp=new XMLHttpRequest()
  4. 如果不可用,则检测 window.ActiveXObject 是否可用。在 Internet Explorer 版本 5.5 及更高版本中,该对象是可用的。
  5. 如果可用,使用它来创建一个新对象:XMLHttp=new ActiveXObject()

改进的例子

一些程序员喜欢使用最新最快的版本的 XMLHttpRequest 对象。

以下例子尝试加载微软最新版本的 "Msxml2.XMLHTTP",在 Internet Explorer 6 中可用,如果无法加载,则退回到 "Microsoft.XMLHTTP",在 Internet Explorer 5.5 及其后续版本中可用。

function GetXmlHttpObject()
{
var xmlHttp=null;
try
 {
 // Firefox, Opera 8.0+, Safari
 xmlHttp=new XMLHttpRequest();
 }
catch (e)
 {
 // Internet Explorer
 try
  {
  xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  }
 catch (e)
  {
  xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
 }
return xmlHttp;
}

Pengertian kod:

  1. Pertama-tama buat objek yang digunakan untuk objek XMLHttpRequest XMLHttp Variabel. Set nilai kepada null.
  2. Buat objek mengikut web standard (Mozilla, Opera serta Safari):XMLHttp=new XMLHttpRequest()
  3. Buat objek mengikut cara Microsoft, boleh digunakan di Internet Explorer 6 dan versi yang lebih tinggi:XMLHttp=new ActiveXObject("Msxml2.XMLHTTP")
  4. Jika kesalahan didapat, cuba kaedah yang lebih lama (Internet Explorer 5.5) :XMLHttp=new ActiveXObject("Microsoft.XMLHTTP")

Lebih banyak maklumat tentang objek XMLHttpRequest

Jika anda mahu baca lebih banyak tentang XMLHttpRequest, sila lawati Panduan AJAX.