if(window.XMLHttpRequest){
xmlObj = new XMLHttpRequest();
} else if(window.ActiveXObject){
xmlObj = new ActiveXObject("Microsoft.XMLHTTP");
} else {
return;
}
这只是一个对不同对象是否可用的测试-某些浏览器实现了不同的XMLHttpRequest对象,所以当我们定义xmlObj作为我们的XMLHttpRequest对象时,我们不得不根据浏览器所实现的来定义它。如果没有可用的XMLHttpRequest对象,我们将执行return语句结束这个函数以避免脚本错误。在大部分情况下,这个检验将返回一个XMLHttpRequest对象-这部分代码应该能够在绝大部分的浏览器上工作,除了少部分比较老的浏览器的异常情况(它能够工作在ie5.01上,但是在netscape4上会使函数终止)。
xmlObj.onreadystatechange = function(){
if(
xmlObj.readyState == 4){
updateObj('
xmlObj',
xmlObj.responseXML.getElementsByTagName('data')[0].firstChild.data);
}
}
每次XMLHttpRequest的状态发生变化,事件onreadystatechange就会被触发。通过使用xmlObj.onreadystatechange = function(){...}我们能够创建一个函数并让它在这个XMLHttpRequest对象的状态每次发生改变的时候立刻运行。这里总共有五个状态,由0走到4。
1.尚未初始化(在这个XMLHttpRequest开始前)
2.加载(XMLHttpRequest初始化一结束)
3.加载结束(XMLHttpRequest一从服务器上获得一个回应)
4.交互(当XMLHttpRequest对象和服务器连接中)
5.结束(当XMLHttpRequest被告知它已经完成了所有人物并结束运行)
这第五个状态(数字4)就是我们能够确定数据已经可用的标志,所以我们检验这个xmlObj.readyState是否等于4来确定数据是否可用,如果是4,我们运行updateObj函数。这个函数带两个参数:一个当前web页面的元素ID(当前web页面中要更新的元素)以及用于填充这个元素的数据。这个函数的运行方式在稍后将更详细地解释。
我们的web页面的p元素有一个idxmlData,这就是我们准备更新的段落。我们正在取得的数据来自于XML文件,但它有点复杂。这里是它如何工作的原理。
xmlObj.responseXML属性是一个DOM对象 - 它很象document对象,除了它来自远程的XML文件。换句话说,如果你在data.xml中运行脚本,那xmlObj.responseXML就是一个document对象。因为我们知道这些,我们能够通过getElementsByTagName方法取得任何XML节点。数据包含在一个命名为<data>的XML节点中,所以我们的任务很简单:取得第一个(而且只有这一个)数据节点。因而,xmlObject.responseXML.getElementsByTagName("data")[0]返回XML文件中的第一个<data>节点。
注意:它返回的是XML节点,而不是节点中的数据-这个数据必须通过访问XML节点的属性取得,这就是下一步要说的。
接下来,取得数据只需要简单的指定firstChild.data(firstChild指向了那个被<data>节点包含的文本节点,而这个data属性则是这个文本节点的实际文本)。
xmlObj.open('GET',file,true);
xmlObj.send('');
这是我们的ajaxRead函数的最后一个部分。它说了些什么?嗯,xmlObj的这个open方法打开了一个到服务器(通过一个指定的协议,这里指定的是GET-你可以使用POST或者其他别的协议)的连接,去请求一个文件(在我们的例子里,变量file被作为一个参数赋给ajaxRead函数-data.xml),而且javascript可以同步(false)或者异步(true,默认值)的处理请求。由于这是异步的Javascript和XML(AJAX),我们将使用默认的异步方式-在这个例子中,使用同步方式将不起作用。