错误循环Ajax(JSON)响应

时间:2012-12-26 20:24:22

标签: javascript jquery ajax json

我正在尝试遍历从php文件返回的数组。

如果我这样做:

  $.ajax({
        type: "POST",
        url: "lib/search/search.standards_one.php",
        async: "false",
        dataType: "json",
        data: {subjects: subjects, grades: grades},
        success: function(response){
            $("#standards_results").html("");
            $.each(response[0], function(){
                  console.log(this['code'], this['standard_id']);
            });
            }
        });

一切都很完美。

但是,我需要使用数组(成绩)作为参数来遍历此响应。

像这样:

  $.ajax({
        type: "POST",
        url: "lib/search/search.standards_one.php",
        async: "false",
        dataType: "json",
        data: {subjects: subjects, grades: grades},
        success: function(response){
                $("#standards_results").html("");
                var len = grades.length;
                var param = "";
                for(var x=0; x < len; x++){
                    param = grades[x];
                    $.each(response[param], function(){
                    console.log(this['code'], this['standard_id']);
                    });
                }
            }
        });

然而,当我运行这个时,我得到“无法读取未定义的属性'长度”错误。

我尝试了很多不同的解决方案,但我仍然得到了这个结果。

////

这是创建JSON对象的地方:

  private function retrieve_standards_one(){
    $dbh = $this->connect();
    $stmt = $dbh->prepare("SELECT code, standard_one_id 
                           FROM standard_one 
                           WHERE grade_id = :grade_id 
                           ORDER BY standard_one_id");
    $stnd = array();
    for($x = 0; $x < (count($this->grades)); $x++){                    
    $stmt->bindParam(':grade_id', $this->grades[$x], PDO::PARAM_STR);
    $stmt->execute();
    $stnd[] = $stmt->fetchAll(PDO::FETCH_ASSOC);
    }
    $json = json_encode($stnd);
    return $json;
}

1 个答案:

答案 0 :(得分:1)

grades超出了您的成功函数的范围,这就是它未定义的原因。 ajax是异步的,因此调用将被触发,并且只有在收到响应时才会执行success函数(并且它已成功)。

快速解决方法是将您需要的变量放在全局范围内,或者如果它们在那里,则从response获取它们。

var len = response.length;