深水池塘

记录学习过程,分享经验和心得

XML初学笔记(八)

【本文是在阅读www.w3school.com.cn的教程时随手记下的内容,以免遗忘】

XMLHttpRequest 对象

XMLHttpRequest 对象提供了在网页加载后与服务器进行通信的方法。

什么是 XMLHttpRequest 对象?

XMLHttpRequest 对象是开发者的梦想,因为您能够:

  • 在不重新加载页面的情况下更新网页
  • 在页面已加载后从服务器请求数据
  • 在页面已加载后从服务器接收数据
  • 在后台向服务器发送数据

所有现代的浏览器都支持 XMLHttpRequest 对象。

创建 XMLHttpRequest 对象

通过一行简单的 JavaScript 代码,我们就可以创建 XMLHttpRequest 对象。

在所有现代浏览器中(包括 IE 7):

 

xmlhttp=new XMLHttpRequest() 

 

Internet Explorer 5 6 中:

 

xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"

 

实例

<script type="text/javascript"> 

var xmlhttp; 

function loadXMLDoc(url) 



xmlhttp
=null

if (window.XMLHttpRequest) 

{// code for all new browsers 

xmlhttp
=new XMLHttpRequest(); 

}
 

else if (window.ActiveXObject) 

{// code for IE5 and IE6 

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

}
 

if (xmlhttp!=null



xmlhttp.onreadystatechange
=state_Change; 

xmlhttp.open(
"GET",url,true); 

xmlhttp.send(
null); 

}
 

else 



alert(
"Your browser does not support XMLHTTP."); 

}
 

}
 


function state_Change() 



if (xmlhttp.readyState==4

{// 4 = "loaded" 

if (xmlhttp.status==200

{// 200 = OK 

// our code here 

}
 

else 



alert(
"Problem retrieving XML data"); 

}
 

}
 

}
 

</script> 


注释:onreadystatechange 是一个事件句柄。它的值 (state_Change) 是一个函数的名称,当 XMLHttpRequest 对象的状态发生改变时,会触发此函数。状态从 0 (uninitialized) 4 (complete) 进行变化。仅在状态为 4 时,我们才执行代码。

为什么使用 Async=true

我们的实例在 open() 的第三个参数中使用了 "true"

该参数规定请求是否异步处理。

True 表示脚本会在 send() 方法之后继续执行,而不等待来自服务器的响应。

onreadystatechange 事件使代码复杂化了。但是这是在没有得到服务器响应的情况下,防止代码停止的最安全的方法。

通过把该参数设置为 "false",可以省去额外的 onreadystatechange 代码。如果在请求失败时是否执行其余的代码无关紧要,那么可以使用这个参数。

Tag标签: XML初学笔记

posted on 2008-06-20 11:31 沉没的青蛙 阅读(21) 评论(0)  编辑 收藏 网摘 所属分类: xml


标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-06-28 12:22 编辑过
Google站内搜索


China-pub 计算机图书网上专卖店!6.5万品种 2-8折!
近千种 9-95 新二手计算图书火热销售中!

相关文章:


相关搜索:
XML初学笔记

相关链接: