jQuery - 每10秒调用一次ajax

ryr*_*yan 34 php ajax jquery

我有一个像这样构造的mysql反馈数据库:

名字| 位置| 反馈

瑞安| 英格兰| 很大的支持

显然,有更多的条目.我正在尝试构建一个反馈div,它通过ajax每隔10秒显示一个新的反馈项.

所以我构建了这个:

$(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(); 
    });
}
Run Code Online (Sandbox Code Playgroud)

这是我的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>
    ";
} 
Run Code Online (Sandbox Code Playgroud)

但是,这只显示了两个.它不会继续显示新的,它纯粹显示第一个然后第二个并停止.

我究竟做错了什么?谢谢 :)

Jar*_*ish 59

你想要做一个setInterval()吗?

setInterval(function(){get_fb();}, 10000);
Run Code Online (Sandbox Code Playgroud)

要么:

setInterval(get_fb, 10000);
Run Code Online (Sandbox Code Playgroud)

或者,如果您希望仅在成功完成呼叫后才能运行,则可以在.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);
}
Run Code Online (Sandbox Code Playgroud)

或者.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);
}
Run Code Online (Sandbox Code Playgroud)

这是两个的演示.注意,成功只能运行一次因为jsfiddle在ajax调用上返回404错误.

http://jsfiddle.net/YXMPn/

  • 如果它是每十秒钟,只有在最后一个用户完成之后,并且你有一个相对较小的用户群(<500并发),我想你会没事的.您只需确保优化PHP脚本. (2认同)

Muh*_*hid 15

setInterval(function()
{ 
    $.ajax({
      type:"post",
      url:"myurl.html",
      datatype:"html",
      success:function(data)
      {
          //do something with response data
      }
    });
}, 10000);//time in milliseconds 
Run Code Online (Sandbox Code Playgroud)