4

我正在尝试解析从数据库返回并编码为 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;
}

这就是我试图解析信息的方式:

  $.ajax({
        type: "POST",
        url: "lib/search/search.standards_one.php",
        async: "false",
        data: {subjects: subjects, grades: grades},
        success: function(response){
                $("#standards_results").html("");
                var obj = $.parseJSON(response);
                $.each(obj, function(){
                    alert(this['code'] + ", " + this['standard_one_id'])
                });
            }
        });

我尝试了许多不同的方法来做到这一点,但我只得到 [object][object] 作为响应。

这是回应:

http://i.imgur.com/E5Hux.png

4

2 回答 2

2

利用

console.log(this['code'] , this['standard_one_id'])

代替

alert(this['code'] + ", " + this['standard_one_id'])
于 2012-12-26T03:10:34.467 回答
0

将 dataType 属性添加到您的 AJAX 调用。

$.ajax ({

    type: "POST",
    dataType: "JSON",
    url: "lib/search/search.standards_one.php",
    async: "false",
    data: {subjects: subjects, grades: grades},
    success: function(response){
            $("#standards_results").html("");
            var obj = $.parseJSON(response);
            $.each(obj, function(){
                alert(this['code'] + ", " + this['standard_one_id'])
            });
        }
    });
于 2012-12-26T03:42:42.907 回答