Javascript 如果我在其中使用警报,则代码可以正常工作,否则无法正常工作
Javascript code is working if I am using alert in it otherwise it's not working
我在 javascript 代码中使用 XMLHttpRequest。
我正在使用 jquery-1.7.1.
如果我在 XMLHttpRequest 之后使用警报,那么下一个代码可以顺利运行,但是当删除该警报时,下一个语句不会获取在 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);
任何 help/suggestion 将不胜感激。
XMLHttpRequest
是异步的。这意味着在到达 $.parseJSON
行之前尚未设置 dyn_data
值。所有依赖于响应的代码都应该放在 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;
}
}
}
我在 javascript 代码中使用 XMLHttpRequest。
我正在使用 jquery-1.7.1.
如果我在 XMLHttpRequest 之后使用警报,那么下一个代码可以顺利运行,但是当删除该警报时,下一个语句不会获取在 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);
任何 help/suggestion 将不胜感激。
XMLHttpRequest
是异步的。这意味着在到达 $.parseJSON
行之前尚未设置 dyn_data
值。所有依赖于响应的代码都应该放在 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;
}
}
}