我有一个像这样构造的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错误.
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)
归档时间: |
|
查看次数: |
88530 次 |
最近记录: |