如果我在其中使用警报,则Javascript代码正常工作,否则它无效

时间:2015-02-19 13:05:39

标签: javascript jquery xmlhttprequest

我在旁边的javascript代码中使用XMLHttpRequest。

我正在使用jquery-1.7.1。

如果我在XMLHttpRequest之后使用alert,则下一个代码可以顺利运行,但是当删除该警报时,下一个语句没有获得在XMLHttpRequest块内初始化的变量值。

以下是我正在使用的代码

var dyn_data='';
if (!xmlhttp && typeof XMLHttpRequest!='undefined')
{
    xmlhttp = new XMLHttpRequest();
}
if (xmlhttp) 
{ 
    var query = 'ACTION=test&format=text';
    xmlhttp.open('POST', 'sample.php'); 
    xmlhttp.setRequestHeader('Content-Type','application/x-www-form-urlencoded; charset=UTF-8');
    xmlhttp.send(query); 
    xmlhttp.onreadystatechange = function() 
        { 
            var arrayindex=0;

            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) 
            {
                dyn_data=xmlhttp.responseText;
            }
        }
}
var obj = $.parseJSON(dyn_data);
alert(obj);
var data=obj;

如果我在上面的代码中评论警报,那么它无效。

我试着在警告的地方发表声明,但这对我来说也不起作用。

setTimeout(function(){  }, 5000);

任何帮助/建议都将不胜感激。

1 个答案:

答案 0 :(得分:1)

XMLHttpRequest是异步的。这意味着在达到dyn_data行之前尚未设置$.parseJSON值。依赖于响应的所有代码都应放在onreadystatechange处理程序中。试试这个:

var xmlhttp;
if (!xmlhttp && typeof XMLHttpRequest!='undefined') {
    xmlhttp = new XMLHttpRequest();
}
else if (xmlhttp) { 
    var query = 'ACTION=test&format=text';
    xmlhttp.open('POST', 'sample.php'); 
    xmlhttp.setRequestHeader('Content-Type','application/x-www-form-urlencoded; charset=UTF-8');
    xmlhttp.send(query); 
    xmlhttp.onreadystatechange = function() { 
        var arrayindex = 0;
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
            var obj = $.parseJSON(xmlhttp.responseText);
            console.log(obj);
            var data = obj;
        }
    }
}