3

我正在尝试调用一个 ajax 请求,直到它返回一个真值。我已经尝试了以下代码,但它没有返回任何结果,并且控制台中没有错误。知道我做错了什么吗?

function getUserData() {
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://api.example.com/data.json", true);
xhr.onreadystatechange = function() {
  if (xhr.readyState == 4) {
    var resp = JSON.parse(xhr.responseText);
    return resp.status;
  }
}
xhr.send();
}

setInterval(function () {
if (getUserData() === "true") {
   alert("true");
}
}, 10000);
4

3 回答 3

5

getUserData在内部调用一个异步函数,所以它在 AJAX 调用实际完成之前很久就返回了。

getUserData而不是在 setInterval 循环中执行此操作,您可能希望在失败情况下再次尝试调用。例如:

function getUserData() {
    var xhr = new XMLHttpRequest();

    xhr.open("GET", "http://api.example.com/data.json", true);
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4) {
            var resp = JSON.parse(xhr.responseText);
            if (resp.status) {
                alert("true");
            } else {
                setTimeout(getUserData, 10000);
            }
        }
    }
    xhr.send();
}

getUserData();
于 2012-11-20T04:46:47.543 回答
0

由于您将其称为异步,因此您无法从函数返回值。尝试这个:

function getUserData() {
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://api.example.com/data.json", true);
xhr.onreadystatechange = function() {
  if (xhr.readyState == 4) {
    var resp = JSON.parse(xhr.responseText);
    if (resp === "true")
        alert("true");
    else
        getUserData();
  }
}
xhr.send();
}
于 2012-11-20T04:47:14.177 回答
0

是的,您的函数将立即返回,但总是返回未定义。

由于操作是异步的,您需要将其重写为基于回调。

function getUserData(callback) {
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://api.example.com/data.json", true);
xhr.onreadystatechange = function() {
  if (xhr.readyState == 4) {
    var resp = JSON.parse(xhr.responseText);
    callback(resp.status);
  }
}
xhr.send();
}

setInterval(function () {
var isTrue = "false";

while(isTrue !== "true"){
   getUserData(function(result){ isTrue = result });
}

}, 10000);
于 2012-11-20T04:49:23.327 回答