jQuery - 每 10 秒调用一次 ajax

2022-08-30 12:12:02

我有一个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(); 
    });
}

这是我的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>
    ";
} 

但是,这仅显示两个。它不会不断显示新的,它纯粹显示第一个然后显示第二个并停止。

我做错了什么?谢谢:)


答案 1

你会想做一个吗?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 在 ajax 调用上返回 404 错误。

http://jsfiddle.net/YXMPn/


答案 2
setInterval(function()
{ 
    $.ajax({
      type:"post",
      url:"myurl.html",
      datatype:"html",
      success:function(data)
      {
          //do something with response data
      }
    });
}, 10000);//time in milliseconds 

推荐