我从来没有理解为什么人们总是在间隔时间添加他们的AJAX请求而不是让成功的AJAX调用只是自己调用,同时冒着通过多个请求严重加载服务器的风险,而不是仅仅在你成功的时候再拨打一个电话回来。
有鉴于此,我喜欢编写解决方案,其中AJAX调用只是在完成时调用自己,如:
// set your delay here, 2 seconds as an example...
var my_delay = 2000;
// call your ajax function when the document is ready...
$(function() {
callAjax();
});
// function that processes your ajax calls...
function callAjax() {
$.ajax({
// ajax parameters here...
// ...
success: function() {
setTimeout(callAjax, my_delay);
}
});
}
我希望这是有道理的! :)
更新
在再次审核之后,我注意到原始问题中的PHP代码中也存在一个问题需要澄清和解决。
虽然上面的脚本在创建AJAX调用之间的延迟方面效果很好,但是当添加到原始帖子中的PHP代码时,脚本只会echo'出现与行数一样多的行数。 SQL查询选择,创建具有相同名称的多个函数,并可能同时进行所有AJAX调用......根本不是很酷......
考虑到这一点,我提出了以下附加解决方案 - 使用PHP脚本创建一个array,一次可以由JavaScript一个元素消化以实现所需的结果。首先,PHP构建JavaScript数组字符串......
include("includes/configuratie.php");
$strSQL = mysql_query("SELECT workerID FROM tWorkers ORDER BY workerID ASC");
// build the array for the JavaScript, needs to be a string...
$javascript_array = '[';
$delimiter = '';
while($row = mysql_fetch_assoc($strSQL))
{
$javascript_array .= $delimiter . '"'. $row['workerID'] .'"'; // with quotes
$delimiter = ',';
}
$javascript_array .= ']';
// should create an array string, something like:
// ["1","2","3"]
?>
接下来,用JavaScript来消化和处理我们刚创建的数组......
// set your delay here, 2 seconds as an example...
var my_delay = 2000;
// add your JavaScript array here too...
var my_row_ids = <?php echo $javascript_array; ?>;
// call your ajax function when the document is ready...
$(function() {
callAjax();
});
// function that processes your ajax calls...
function callAjax() {
// check to see if there are id's remaining...
if (my_row_ids.length > 0)
{
// get the next id, and remove it from the array...
var next_id = my_row_ids[0];
my_row_ids.shift();
$.ajax({
cache : false,
url : 'ajax2.php',
data : "workerID=" + next_id, // next ID here!
dataType : 'json',
success : function(data) {
// do necessary things here...
// call your AJAX function again, with delay...
setTimeout(callAjax, my_delay);
}
});
}
}