我正在尝试制作一个AJAX GET请求,但我根本无法让它工作。我想检索example.com的HTML源代码。我之前使用过JQuery来发送AJAX请求,但我只使用JQuery来实现其AJAX功能,因此将30KB文件包含在一个任务中是浪费。我做错了什么?
<script type="text/javascript">
var XMLHttpArray = [
function() {return new XMLHttpRequest()},
function() {return new ActiveXObject("Msxml2.XMLHTTP")},
function() {return new ActiveXObject("Msxml2.XMLHTTP")},
function() {return new ActiveXObject("Microsoft.XMLHTTP")}
];
function createXMLHTTPObject(){
var xmlhttp = false;
for(var i=0; i<XMLHttpArray.length; i++){
try{
xmlhttp = XMLHttpArray[i]();
}catch(e){
continue;
}
break;
}
return xmlhttp;
}
function AjaxRequest(url,method){
var req = createXMLHTTPObject();
req.onreadystatechange= function(){
if(req.readyState != 4) return;
if(req.status != 200) return;
return req.responseText;
}
req.open(method,url,true);
req.send(null);
}
function MakeRequst(){
var result=AjaxRequest("http://example.com","get");
alert(result);
}
</script>
答案 0 :(得分:2)
从状态更改处理程序返回一个值对您没有任何好处 - 代码正在等待某些事情发生,并且在处理HTTP请求时从浏览器内部调用它。它是异步。
您的状态更改处理程序必须自行处理响应,而不是期望这样的结果。
function AjaxRequest(url,method){
var req = createXMLHTTPObject();
req.onreadystatechange= function(){
if(req.readyState != 4) return;
if(req.status != 200) return;
alert(req.responseText);
}
req.open(method,url,true);
req.send(null);
}