如何使用jQuery刷新数据库查询

时间:2015-07-18 02:13:38

标签: php jquery css

我正在进行一项真正的基本聊天,主要是基于PHP的。我想使用jQuery检查新消息并每隔几秒更新一次#cbox div。到目前为止,我已尝试使用下面的代码完成它。对于一个参考框架,这是我第一次将jQuery包含在我的任何脚本中,所以这个问题可能是一个非常简单的错误,我在我的新事物中忽略了。

我遇到的问题是#cbox div显示为空白,它似乎根本没有调用chat_post.php。我也会发布那些代码,以防问题出在那里而不是我的jQuery。为了解决这个问题,我尝试在<div id='cbox'>中加入chat_post.php,但没有产生任何结果。在这一点上,我非常关注稻草。

<div id='sb_content'>
    <center><div id='chat'>

        <div id='ribbon' style='position: relative; margin-top:-50px; margin-left:-32px;'><center><span class='ribbon'>chat box</span></center></div>
        <div style='margin-top: -20px;'><center><span style='text-shadow: 0 0 0.2em #000;' class='admin'>admin</span> || <span style='text-shadow: 0 0 0.2em #000;' class='mod'>mod</span></center></div>

        <div id="cbox">
        <script>
        $(document).ready(function() {
            setInterval(function(){getUpdates()}, 2000); 
        });

        function getUpdates() {
            $("#cbox").load("chat_post.php");
        }
        </script>
        </div>

        <form name="message" method='post' action="chat_post.php" id="cbox_input">
            <input name="usermsg"id='usermsg' type="text" size="63" maxlength="255" />
        </form>

    </div></center>
    </div>

chat_post.php

<div id='cbox' align='left'>

<?php

$username = $_SESSION['login'];
$ug = $_SESSION['user_group'];


// Display messages
$sql = <<<SQL
SELECT *
FROM `chat_entries`
ORDER BY `ts` DESC
LIMIT 0,50
SQL;

$result = $db->query($sql);
$count = $result->num_rows;

if ($count != 0){
    while ($row = mysqli_fetch_array($result)) {
            $c_name = $row['author'];
            $c_text = $row['text'];
            $c_ts = $row['ts'];
            $c_id = $row['id'];

$sqlm = <<<SQL
SELECT *
FROM `users`
WHERE username = '$c_name'
SQL;

            $resultm = $db->query($sqlm);
            $countm = $resultm->num_rows;

            if ($count != 0){
                while ($rowm = mysqli_fetch_array($resultm)) {
                    $c_level = $rowm['user_group'];
                }
            }

            if ($c_level == 'mod') {
                echo "
                <a href='/user/" . $c_name . "' class='mod'>" . $c_name . "</a>
                ";
            }

            if ($c_level == 'admin') {
                echo "
                <a href='/user/" . $c_name . "' class='admin'>" . $c_name . "</a>
                ";
            }

            if ($c_level == 'member') {
                echo "
                <a href='/user/" . $c_name . "' class='member'>" . $c_name . "</a>
                ";
            }

            if ($c_level == 'guest') {
                echo "
                <i>" . $c_name . "</i>
                ";
            }

            echo "
            : " . $c_text . "<div id='cbox_div'>";

            echo "<span style='float:left;'><i>" . $c_ts . "</i></span>";

            echo "<span style='float:right;'>";

            if ($ug == 'mod' || $ug == 'admin'){
                echo " <a href='#'>Delete</a> || <a href='#'>Block</a> ||";
            }

            if ($_SESSION['login']) {
                echo "<a href=/report/?type=chat?id=" . $c_id . ">Report</a></span></div>
                ";
            }
    }
}
?>

1 个答案:

答案 0 :(得分:0)

删除chat_post.php上的额外ID后,我的代码工作正常。有趣的事情如此简单可以真正搞砸了。 (:谢谢大家的帮助!