-1

PHP、AJAX、MySQL、および json コーディングを使用して、単純なコメント バーを作成しようとしています。

PHP で記述された 2 つのファイルがあります。最初のファイルは、次のコードを含むコントローラーです。

<?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";
        }
        }


    }

?>

2 つ目は、コントローラーからのデータに基づいて、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サーバーを使用しています。

4

1 に答える 1

1

JavaScript コードでは、実際には JavaScript では未定義のオブジェクトであるcomments.<xxx>ためcomment.<xxx>、に置き換える必要があります。comments

于 2013-06-01T20:13:09.377 に答える