1

我知道使用同步请求不是一个好主意,但我确实需要它。

getEndDate如果响应长度小于 20,我尝试对自身进行函数调用,但是在第一个不成功的请求(如果 url 给出的响应太短)之后,它会转到alert(enddate.EDDAYOW);并且我收到错误,并getEndDate继续每 500 毫秒发送一次请求。

我需要getEndDate函数继续发送请求,直到它得到有效响应并返回有效对象,然后才继续到下一行 JS。如何做到这一点?

var url = 'http://local.com/cgi-bin/hello2.pl';
// url returns a plain text:
// 1234567890 2013 05 May Friday 13 23 45 01


var enddate = getEndDate(url);

alert(enddate.EDDAYOW);

function getEndDate(url) {
    var xmlhttp = getXmlHttp();
    xmlhttp.open('GET', url, false);
    xmlhttp.send();
    if (xmlhttp.status == 200 && xmlhttp.responseText.length > 20) {
        var n = xmlhttp.responseText.split(" ");
        return {
            'edseconds': n[0],
            'EDYEAR': n[1],
            'EDMON': n[2],
            'EDMONNAME': n[3],
            'EDDAYOW': n[4],
            'EDDAY': n[5],
            'EDHOUR': n[6],
            'EDMIN': n[7],
            'EDSEC': n[8]
        };
    } else {
        setTimeout("getEndDate(" + url + ")", 500);
    }
}


function getXmlHttp() {
    var xmlhttp;
    try {
        xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
    } catch (e) {
        try {
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
        } catch (E) {
            xmlhttp = false;
        }
    }
    if (!xmlhttp && typeof XMLHttpRequest != 'undefined') {
        xmlhttp = new XMLHttpRequest();
    }
    return xmlhttp;
}
4

1 回答 1

2

我不知道这是否满足您的要求,但我会将其重写为如下内容:

var enddate;

getEndDate(url);

function do_rest(returnDate)
{
    enddate = returnDate;
    alert(enddate.EDDAYOW);

    // do more if you need
};


function getEndDate(url) {
    var xmlhttp = getXmlHttp();

    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4) {
            if (xmlhttp.status == 200 && xmlhttp.responseText.length > 20) {
                var n = xmlhttp.responseText.split(" ");
                do_rest({
                    'edseconds': n[0],
                    'EDYEAR': n[1],
                    'EDMON': n[2],
                    'EDMONNAME': n[3],
                    'EDDAYOW': n[4],
                    'EDDAY': n[5],
                    'EDHOUR': n[6],
                    'EDMIN': n[7],
                    'EDSEC': n[8]
                });
            } else {
                setTimeout("getEndDate(" + url + ")", 500);
            }
        }
    }


    xmlhttp.open('GET', url, false);
    xmlhttp.send();
}
于 2013-05-12T23:59:36.307 回答