javascript与dom编程(五)ajax
一:创建XMLHttpRequest对象
在使用XMLHttpRequest对象发送请求和处理响应之前,必须先用JavaScript创建一个XMLHttpRequest对象,在IE(5、6)中是把XMLHttpRequest实现为一个ActiveX对象,如:var requester = new ActiveXObject("Micrsoft.xmlHTTP");
其它的浏览器包括IE7是把实现为一个JavaScript对象。如:
var requester = new XMLHttpRequest();
我们可以通过try-catch,在不同的浏览器中,正确的创建XMLHttpRequest对象。
try
{
var requester = new XMLHttpRequest();
}
catch(error)
{
try
{
var requester = new ActiveXObject("Microsoft.XMLHTTP");
}
catch(error)
{
var requester = null;
}
}
二:与服务器通信
创建好XMLHttpRequest后,我们需要调用open和send两个方法,用来从服务器取得数据。
open用来初始化与服务器的连接,它带有两个必选的参数。第一个参数为请求的方式,(get,post,put),第二个为获得数据的url地址。例如:
requester.open("GET", "/feed.xml", true);第三个参数指定请求是异步还是同步,默认为异步。
send方法激活此连接,向服务器发送请求。当使用POST请求时,send允许发送一个已经编码过的参数。
requester.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");//Opera浏览器下
requester.open("POST", "/query.php", true);
requester.send("name=Clark&email=superman@justiceleague.xmp");
使用GET时,参数必须随着url传送。例如:
requester.open("GET",
"query.php?name=Clark&email=superman@justiceleague.xmp", true);
requester.send(null);
在IE下,send不需要任何参数,但是在firefox中则会出现错误。所以我们必须给send一个null的参数。
调用send后,XMLHttpRequest将会与服务器通信,返回你所请求的数据。为了确认服务器已经响应请求,我们可以监视XMLHttpRequest的readyState属性,有5个可取值,0=初始化,1=正在加载,2=已加载,3=交互中,4=完成。
请求完成后,我们还必须确认XMLHttpRequest是否正确得到数据,我们可以查看status的HTTP状态码,200对应OK,404对应Not Found。
三:处理数据
1:responseXML:服务器的响应,表示为XML,可以解析为一个DOM对象。
2:responseText:服务器的响应,表示为一个串。