Здравствуйте, пожалуйста подскажите как реализовать ajax-запрос для подсчета сообщений из БД и их удаления (не существующие сообщения в БД), если надо.
На данный момент функция получения новых сообщений выглядит:
function get_chat_messages ()
{
if ($('#block').val() == 'no') // если не выставлена блокировка повторного выполнения данной функции, продолжаем
{
$('#block').val('yes'); // ставим блокировку
var last_act = $('#last_act').val();
$.ajax(
{
url: 'func/chat_scripts.php',
type: 'POST',
data:
{
'action': 'get_chat_message',
'last_act': last_act
},
dataType: 'json',
success: function (result)
{
$('#block').val('no');
$('#chat_text_field').append(result.message_code); // добавляем в текстовое поле новые сообщения
$('#last_act').val(result.last_act); // обновляем значение последнего сообщения
// автопрокрутка текстового поля вниз
$('#chat_text_field').scrollTop($('#chat_text_field').scrollTop()+100*$('.chat_post_my, .chat_post_other').size());
} // конец success
}); // конец ajax
}
}
Сервер обрабатывает:
// получение новых сообщений
if ($_POST['action'] == 'get_chat_message')
{
$last_act = safe_var($_POST['last_act']); // номер бывшего последнего сообщения
$sel_result = mysql_query("SELECT * FROM chat_logs WHERE id > '$last_act' ORDER BY message_date ASC, id ASC");
if (mysql_num_rows($sel_result)>0)
{
$sel_row = mysql_fetch_array($sel_result);
do
{
if ($sel_row['nickname'] == $_SESSION['login']) // собственное сообщение
{
$message_code .= '<p class="chat_post_my"><span class="chat_mess_time"><strong>['.date("H:i:s",strtotime($sel_row['message_date'])).']</strong> - </span><span class="chat_nickname">'.$sel_row['nickname'].': </span>'.$sel_row['message_text'].'</p>';
}
else // чужое сообщение
{
$message_code .= '<p class="chat_post_other"><span class="chat_mess_time"><strong>['.date("H:i:s",strtotime($sel_row['message_date'])).']</strong> - </span><span class="chat_nickname" onclick="chat.splace2(\''.$sel_row['nickname'].',\',\'bb\');"><a href="#">'.$sel_row['nickname'].'</a>: </span>'.$sel_row['message_text'].'</p>';
}
$last_act = $sel_row['id']; // номер текущего последнего сообщения
}
while($sel_row = mysql_fetch_array($sel_result));
$message_code = preg_replace("/(\[)([abc]{1,1}[a-z]{1,1}|[d]{1,1}[a-v]{1,1})(\])/","<img src=\"images/smiles/\${2}.gif\" />",$message_code,-1);
// отправляем полученные переменные в формате json
$data_str = array('message_code' => $message_code, 'last_act' => $last_act);
echo json_encode($data_str);
}
}