写道
function getHTTPObject()
{
var xmlhttp=null;
if (window.XMLHttpRequest)
{
xmlhttp=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlhttp;
}
var http = getHTTPObject();
function loadXMLDoc(name, parseFunc)
{
http.open("GET", name, true);
http.onreadystatechange = parseFunc;
http.send(null);
}
{
var xmlhttp=null;
if (window.XMLHttpRequest)
{
xmlhttp=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlhttp;
}
var http = getHTTPObject();
function loadXMLDoc(name, parseFunc)
{
http.open("GET", name, true);
http.onreadystatechange = parseFunc;
http.send(null);
}
loadXMLDoc('api/getmatype.jsp', parseMATypeSelect);
loadXMLDoc('api/getmslink.jsp',parseMSlinkSelect);
loadXMLDoc('api/getmslink.jsp',parseMSlinkSelect);
实际执行时,发现第一个loadXMLDoc执行的结果总是没有出现,好像没有执行。
其实,是因为
http.open("GET", name, true); //异步调用
改成false就好了。
参考资料:
XMLHTTP依赖于XMLHttpRequest完成从客户端的请求到服务端的应答。
XMLHttpRequest提供了两个方法open和send。open方法用于初始化XMLHttpRequest对象、指示请求的方式(get、post等)、安全性连接等,在调用open方法后必须调用send方法发送Http Request(Http请求)以返回Http Reponse(Http应答)。
如果设置成异步,则不等待send的返回,而直接执行接下来的代码,这样子就出现了第一个loadXMLDoc执行,但是结果没有返回,就去执行第二个去了,而他们使用的是同一个xmlhttp;