同时执行javascript问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了同时执行javascript问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1568字,纯文字阅读大概需要3分钟。
内容图文
我正在尝试在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>
输出为:
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);
}
但是,请理解,一个或多个请求可能会挂在服务器上,从而允许后一个请求先完成,这可能会导致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);
}
内容总结
以上是互联网集市为您收集整理的同时执行javascript问题全部内容,希望文章能够帮你解决同时执行javascript问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。