我有一个包含行的表样式页面。每一行都有一个复选框。我可以选择所有/许多复选框,然后单击“提交”,每行的Jquery ajax调用是什么。如何知道所有ajax调用何时完成
基本上我有一个每行的表单,我遍历所有检查的行并提交表单,它执行jquery ajax调用。
所以我有一个按钮,做:
$("input:checked").parent("form").submit();
然后每行有:
<form name="MyForm<%=i%>" action="javascript:processRow(<%=i%>)" method="post" style="margin:0px;">
<input type="checkbox" name="X" value="XChecked"/>
<input type="hidden" id="XNumber<%=i%>" name="X<%=i%>" value="<%=XNumber%>"/>
<input type="hidden" id="XId<%=i%>" name="XId<%=i%>" value="<%=XNumber%>"/>
<input type="hidden" id="XAmt<%=i%>" name="XAmt<%=i%>" value="<%=XAmount%>"/>
<input type="hidden" name="X" value="rXChecked"/>
</form>
这种形式提交给processRow:
function processRow(rowNum)
{
var Amount = $('#XAmt'+rowNum).val();
var XId = $('#XId'+rowNum).val();
var XNum = $('#OrderNumber'+rowNum).val();
var queryString = "xAmt=" + "1.00" + "&xNumber=" + OrdNum + "&xId=" + xId;
$('#coda_'+rowNum).removeClass("loader");
$('#coda_'+rowNum).addClass("loading");
$.ajax({
url: "x.asp",
cache: false,
type: "POST",
data: queryString,
success: function(html){
$('#result_'+rowNum).empty().append(html);
$('#coda_'+rowNum).removeClass("loading");
$('#coda_'+rowNum).addClass("loader");
}
});
}
我想知道是什么,从这里可以看出我的所有Ajax调用是否完成。原因是希望在所有这些调用发生时启用/禁用提交按钮。
谢谢,请注意,由于应用程序的敏感性,我不得不打乱我的变量名,所以很多可能会被复制。
在检测所有ajax调用何时完成对任何设计都有价值时,我认为更好的整体解决方案是一次提交多行。发送每一行作为一个单独的ajax文章将在某些方面*真的很难在系统上,而不是(在我看来)是最好的设计。我甚至会说,*我承诺*有一天,如果你坚持这种设计的一个ajax-call-per-row,你会后悔的。 – ErikE 2015-10-05 17:34:50
除了@ErikE指出的设计问题外,我很惊讶没有人提到使用Promise来回答原始问题。 – 2016-07-27 21:17:48