没有警报,AJAX功能不起作用

时间:2012-08-28 16:09:01

标签: php javascript ajax xmlhttprequest

我在我的网站上使用了大量的带有XML Http请求的AJAX。对于看似随机的几个AJAX调用,我无法在onreadystatechange函数中获取所有javascript以正确执行,除非我有一个警报调用,我猜测暂停执行足以让它完成运行PHP脚本服务器。这是我正在谈论的一个例子:

的Javascript

xmlHttp=getXMLHttp();   //function returns an xmlhttp object to use
//get parameters ready
param="id=5"
xmlHttp.onreadystatechange=function(){
    if(xmlHttp.readyState==4){
        s=xmlHttp.responseText;
        var myJson = eval("("+s+")");
        document.getElementById('Elem1').value=myJson.Result1;
        document.getElementById('Elem2').value=myJson.Result2;
        triggerEvent(document.getElementById('Elem3'),'onblur');
        document.getElementById('Elem4').value=myJson.Result3;
        document.getElementById('Elem5').value=myJson.Result4
        var sel = document.getElementById('Elem6');
        var i;
        for(i=0;i<sel.length;++i){
            if(sel.options[i].value==myJson.Result5){
                sel.selectedIndex = i;
                break;
            }
        }
        document.getElementById('MfgCustNum').value=myJson.Result6;
        document.getElementById('MfgOrderNum').value=myJson.Result7;
        document.getElementById('OrderDatePicker').value=myJson.Result8;
        document.getElementById('ShipDatePicker').value=myJson.Result9;
        document.getElementById('CancelDatePicker').value=myJson.Result10;
        document.getElementById('PO Number').value=myJson.Result11;
        //for some reason, the following 2 lines are where I'm having issues without an alert box
 document.getElementById('NewElement').value=myJson.Result12;
     document.getElementById('NewElement2').value=myJson.Result13;
 //everything else loads properly
        sel = document.getElementById('SelectBox1')
        for(i=0;i<sel.length;++i){
            if(sel.options[i].value==myJson.Result14){
                sel.selectedIndex = i;
                break;
            }
        }
        sel = document.getElementById('SelectBox2')
        for(i=0;i<sel.length;++i){
            if(sel.options[i].value==myJson.Result15){
                sel.selectedIndex = i;
                break;
            }
        }
        sel = document.getElementById('SelectBox3')
        for(i=0;i<sel.length;++i){
            if(sel.options[i].value==myJson.Result16){
                sel.selectedIndex = i;
                break;
            }
        }
        sel = document.getElementById('SelectBox4')
        for(i=0;i<sel.length;++i){
            if(sel.options[i].value==myJson.Result17){
                sel.selectedIndex = i;
                break;
            }
        }
    }
}
xmlHttp.open("POST","../ServerCall.php",true);
xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlHttp.send(params);

我正在运行的PHP脚本是对作为JSON数组回显的数据库的简单查询

    $dc->connect();
    $query = "SELECT COLUMNS FROM TABLE"
    $res = $dc->queryDb($query);
    if(!$res){
        exit();
    }
    $ary = $dc->resultsToArray($res);
    $JSON_ARRAY=array();
    foreach($ary[0] as $key=>$value){
        if(!is_numeric($key))
            $JSON_ARRAY[$key]=$value;
    }
    echo json_encode($JSON_ARRAY);

这对我来说已经成为一个非常大的问题,因为它现在发生在我的代码的3或4个不同部分,但是在响应文本中放入警报对话框显示一切正常运行。我已经尝试同步运行AJAX调用而不是异步,但它没有帮助。我也尝试使用settimeout延迟运行一两秒的代码,但是我的结果好坏参半,我宁愿不必为脚本设置特定的延迟来运行。

编辑: 要回答评论中的一些问题: 对于此代码段,问题在于以下两行:

 document.getElementById('NewElement').value=myJson.Result12;
 document.getElementById('NewElement2').value=myJson.Result13;

如果我在该行之前放置一个警告框来获取myJson.Result12的文本,那么这些元素将在我的页面上正确填充。没有它,它们会留空,并且在Firefox的错误控制台中没有出现错误

此代码正在运行onclick。我正在使用DataTables,当有人双击表格中的一行时,页面会填充内容。同样,除了我今天早些时候添加的2个新元素之外,一切正常。更大的问题是如何在我的代码中这似乎是一个反复出现的问题。

另外,我已经尝试过jQuery的AJAX调用,但是运气不好,我的大部分代码都是用xmlHttp编写的,只有JS。

2 个答案:

答案 0 :(得分:1)

可能的原因;

您应该从onload处理程序执行AJAX请求,否则在获得响应时您的页面可能无法完全加载。如果在您尝试更新NewElement和NewElement2时没有加载它们,则您的脚本将无效。

警报会使脚本延迟到足以让页面完成加载,允许元素在脚本到达该点之前存在。

答案 1 :(得分:0)

所以现在,数据似乎加载得很好,没有警告框来暂停脚本。我不确定现在有什么不同,但我会继续尝试重现错误。我想知道问题是基于我使用的浏览器还是计算机而不是代码本身不能正常工作。或者数据库响应速度较慢会导致一些问题。 FWIW,我试图接收的列,虽然没有填充太多数据,但我试图选择的所有列的最大最大值。

感谢大家的帮助。在评论中使用AJAX肯定有很多好的建议。