我有一个这样构造的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()
setInterval(function(){get_fb();}, 10000);
要么:
setInterval(get_fb, 10000);
或者,如果您希望它仅在成功完成呼叫后才运行,则可以在.ajax().success()回调中进行设置:
.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()如果您希望它运行而不考虑结果,请使用:
.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/