我在旁边的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);
任何帮助/建议都将不胜感激。
答案 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;
}
}
}