bla*_*rws 1 javascript ajax while-loop do-while
我正在尝试在do while循环中发送多个帖子,但结果未添加
<script type="text/javascript">
function action() {
var initval = 1;
var endval = 5;
do {
var action_string = 'txtuser=someone';
$.ajax({
type: "POST",
url: "http://localhost/js.php",
data: action_string,
success: function(result){
$('div#append_result').append(initval + ',<br/>');
}
});
initval++;
} while (initval <= endval);
}
</script>
Run Code Online (Sandbox Code Playgroud)
输出为:5,5,5,5,5,
我需要输出为:1,2,3,4,5,
由于AJAX的异步特性,当您的成功函数针对任何生成的AJAX请求运行时,循环已完成并initval设置为5.您需要捕获initval每个请求开始时的状态并使用捕获的success()方法中的状态.关闭该值是最简单的方法:
function action() {
var initval = 1;
var endval = 5;
do {
var action_string = 'txtuser=someone';
( function( captured_initval ){
$.ajax({
type: "POST",
url: "http://localhost/js.php",
data: action_string,
success: function(result){
$('div#append_result').append(captured_initval + ',<br/>');
}
});
}( initval ) );
initval++;
} while (initval <= endval);
}
Run Code Online (Sandbox Code Playgroud)
但是要明白,一个或多个请求可能会在服务器上挂起,从而允许后一个请求首先完成,这可能导致1, 2, 5, 3, 4或类似的事情.
此外,使用元素的ID比使用元素标记名称为哈希选择器添加前缀要快得多.此外,每次成功运行时,您都应该避免为结果DIV重新查询DOM.抓住一次,在需要时使用它:
function action() {
var initval = 1;
var endval = 5;
do {
var action_string = 'txtuser=someone',
$AppendResult = $('#append_result');
( function( captured_initval ){
$.ajax({
type: "POST",
url: "http://localhost/js.php",
data: action_string,
success: function(result){
$AppendResult.append(captured_initval + ',<br/>');
}
});
}( initval ) );
initval++;
} while (initval <= endval);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3430 次 |
| 最近记录: |