评论栏mysql php和ajax

时间:2013-06-01 16:43:56

标签: php mysql ajax json apache

我正在尝试使用PHP,AJAX,MySQL和json编码创建一个简单的注释栏。

我有两个用php编写的文件,第一个是带有以下代码的控制器:

<?php
    require("../includes/config.php");
    if ($_SERVER["REQUEST_METHOD"] == "GET") {

        $comments = query("SELECT comments.comment, comments.author, comments.time FROM comments WHERE workid = ?", $_GET["workid"]);
        echo json_encode($comments);

    }
    else if ($_SERVER["REQUEST_METHOD"] == "POST") {
        if (empty($_SESSION["userid"])) {
            throw new Exception("Login");
        }
        else {

        $result = query("INSERT INTO comments (comment, author, time, workid) VALUES(?, ?, ?, ?)", $_POST["text"], $_SESSION["userid"], date("Y-m-d H-i-s"), $_POST["workid"]);
        if ($result !== false) {
            echo "success";
        }
        }


    }

?>

第二个据称是根据来自控制器的数据显示来自MySQL的记录:

<script>
//loads the comments
$(document).ready(function(){
    var comment;
    $.ajax({
        type: "GET",
        url: "../html/comments.php",
        data: {
            workid: <?php echo $id;?>
        },
        dataType: "json",
        success: function(e) {
            var lis = "";
            for (var i = 0; i < e.length; i++) {
                comment = e[i];
                lis +=

                "<li class='comment'>" + 
                "<div class='well'>" +
                "<p>" + 
                "<a class='username' href='#'>" + comments.author + ": " + "</a>" +
                comments.comment + 


                "</p>" + 

                "<small class='pull-right'>" + comments.time + "</small>" +

                "</div>" + 

                "</li>";



            }
            $("#comments").html(lis);

        },
        error: function(e) {
            $("#comments").html(
                "<li class='comment'> Couldn't load comments </li>"
                );
        }

    });
});
</script>

<script>
$(document).ready(function(){
    $("#comment-button").click(function(){

        $.ajax({
            type: "POST",
            url: "../html/comments.php",
            data: {
                workid: <?php echo $id;?>,
                text: $("#comment-textarea").val()
            },
            dataType: "text",
            success: function(e) {
                var comment;
                $.ajax({
                    type: "GET",
                    url: "../html/comments.php",
                    data: {
                        workid: <?php echo $id;?>
                    },
                    dataType: "json",
                    success: function(e) {
                        var lis = "";
                        for (var i = 0; i < e.length; i++) {
                            comment = e[i];

                            lis +=

                            "<li class='comment'>" + 
                            "<div class='well'>" +
                            "<p>" + 
                            "<a class='username' href='#'>" + comments.author + ": " + "</a>" +
                            comments.domment + 


                            "</p>" + 

                            "<small class='pull-right'>" + comments.time + "</small>" +

                            "</div>" + 

                            "</li>";



                        }
                        $("#comments").html(lis);
                        $("#comment-textarea").val("");

                    },
                    error: function(e) {
                        $("#comments").html(
                            "<li class='comment'> Couldn't load comments </li>"
                            );
                    }

                });
            }


        });


});
});
</script>

除最后一步外,一切都很好;在显示数据库中的数据时,唯一显示的是“未定义”语句而不是核心数据。除此之外,评论和表格的数量正确显示。我正在使用安装了php的Apache服务器。

1 个答案:

答案 0 :(得分:1)

在您的JavaScript代码中,您需要将comments.<xxx>替换为comment.<xxx>,因为comments确实是JaveScript中未定义的对象。