为了合并一些sql调用,我尝试对服务器进行一次查询,然后让客户端遍历每个结果.需要注意的是,在处理下一个结果之前,我需要等待用户输入.这可能吗?
$.post('functions/file_functions.PHP', {type: 'test', f: 'load'}, function(data) {
if (data.success) {
$.each(data.files, function() {
// Can I wait for user input at this point and then process the next
// file after a users interaction (e.g. a button click)?
});
}
}, "json");
解决方法:
我将对我的评论进行一些扩展,并希望使它成为一个有用的答案. JavaScript是单线程的,因此在等待其他事件(例如,被单击的元素)发生时,无法阻止函数的执行.相反,您可以做的是,当AJAX POST请求成功返回时,将文件列表存储到数组中,然后使用单独的click事件处理程序来循环浏览它们(我假设每次单击都获得一个文件).
代码可能看起来像这样:
$(function() {
var files, index = 0;
$.post('functions/file_functions.PHP', {type: 'test', f: 'load'}, function(data) {
if (data.success) {
files = data.files;
}
}, "json");
$('.mybutton').click(function() {
if(files) {
var file = files[index++];
// do something with the current file
}
});
});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。