我已经在页面上创建了 webMethod,这些方法将在客户端使用 $.ajax() 调用。第一个 Webmethod 正在处理耗时的任务。任务需要 8 分钟以上才能完成。在对第一个方法进行 ajax 调用后,我立即调用另一个 Web 方法,该方法在一秒或 2 内完成。所以我应该立即从第二个 WebMethod ajax 调用中获得响应。但是在这里,在这种情况下,第二个 Web 方法直到第一次调用完成才执行。下面的示例模拟我的场景。
[WebMethod]
public static string PullData(int snapshotId)
{
string str = "Pull Started: " + DateTime.Now.ToString() + "\n";
Thread.Sleep(30000);
str += "Pull End: " + DateTime.Now.ToString();
return new JavaScriptSerializer().Serialize(str);
}
[WebMethod]
public static string CheckStatus(int snapshotId)
{
return new JavaScriptSerializer().Serialize("Check Status" + DateTime.Now.ToString());
}
下面是点击按钮时的 Javascript 调用。
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
<script language="javascript" type="text/javascript">
function pullData(){
$.ajax({ type: 'POST',
url: 'Default.aspx/PullData',
data: '{ snapshotId: 101 }',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (msg) {
var curMsg = $("#message").attr("innerHTML") + "<br />";
$("#message").attr("innerHTML", curMsg + msg.d);
},
error: function (jqXHR, textStatus, errorThrown) {
alert(jqXHR.responseText);
}
});
CheckStatus();
return false;
}
function CheckStatus() {
//alert("this is check status");
$.ajax({ type: 'POST',
url: 'Default.aspx/CheckStatus',
data: '{ snapshotId: 101 }',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (msg) {
var curMsg = $("#message").attr("innerHTML") + "<br />";
$("#message").attr("innerHTML", curMsg + msg.d);
},
error: function (jqXHR, textStatus, errorThrown) {
alert(jqXHR.responseText);
}
});
return false;
}
</script>
在上面调用CheckStatus方法应该返回响应,在PullData方法返回响应之前。但是CheckStatus在PullData完成其工作后执行。
我可能在这里失踪或不知道完整的行为。请帮忙!!!
有人遇到过这个问题吗?