jQuery - вызывайте ajax каждые 10 секунд - PullRequest
31 голосов
/ 16 апреля 2011

У меня есть база данных обратной связи mysql, сконструированная так:

name |местоположение |обратная связь

Райан |Англия |отличная поддержка

Очевидно, что больше записей, чем это.Я пытаюсь создать div обратной связи, где он отображает новый элемент обратной связи каждые 10 секунд через ajax.

Итак, я построил это:

$(document).ready(function(){
   new get_fb(); 
 });

function get_fb(){
var feedback = $.ajax({//Ajax
                        type: "POST",
                        url: "feedback.php",
                        async: false
                        }).responseText;//end of ajax

$('div.feedback-box').html(feedback).delay(10000).queue(function() {
    new get_fb(); 
    });
}

И вот мой PHP-файл:

$result = mysql_query("SELECT * FROM feedback ORDER BY RAND() LIMIT 0,1");
while($row = mysql_fetch_array($result))
{
    $name = $row['name'];
    $location = $row['location'];
    $feedback = $row['feedback'];

    echo "
    <p>Name: $name, Location: $location, Feedback: $feedback.</p>
    ";
} 

Однако, это показывает только два.Он не показывает новые, он показывает только первое, затем второе и останавливается.

Что я делаю не так?Спасибо:)

Ответы [ 3 ]

56 голосов
/ 16 апреля 2011

Вы хотите сделать setInterval()?

setInterval(function(){get_fb();}, 10000);

Или:

setInterval(get_fb, 10000);

Или, если хотите, чтобы он работал только после успешного завершения вызова,Вы можете установить его в своем .ajax().success() обратном вызове:

function get_fb(){
    var feedback = $.ajax({
        type: "POST",
        url: "feedback.php",
        async: false
    }).success(function(){
        setTimeout(function(){get_fb();}, 10000);
    }).responseText;

    $('div.feedback-box').html(feedback);
}

Или использовать .ajax().complete(), если хотите, чтобы он работал независимо от результата:

function get_fb(){
    var feedback = $.ajax({
        type: "POST",
        url: "feedback.php",
        async: false
    }).complete(function(){
        setTimeout(function(){get_fb();}, 10000);
    }).responseText;

    $('div.feedback-box').html(feedback);
}

Вот демонстрациядва.Обратите внимание, что успех работает только один раз, потому что jsfiddle возвращает ошибку 404 при вызове ajax.

http://jsfiddle.net/YXMPn/

14 голосов
/ 16 апреля 2011
setInterval(function()
{ 
    $.ajax({
      type:"post",
      url:"myurl.html",
      datatype:"html",
      success:function(data)
      {
          //do something with response data
      }
    });
}, 10000);//time in milliseconds 
3 голосов
/ 16 апреля 2011

Вместо этого вы можете попробовать использовать setInterval ():

var i = setInterval(function(){
   //Call ajax here
},10000)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...