jQuery-每10秒调用ajax

我有一个这样构造的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>

";

}

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

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

回答:

你想做一个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错误。

以上是 jQuery-每10秒调用ajax 的全部内容, 来源链接: utcz.com/qa/399162.html

回到顶部