【发布时间】:2016-03-22 15:18:32
【问题描述】:
我想实现以下功能: 第一个 AJAX 请求将数据导入 MS SQL 数据库。数据库中有一个表,其中包含一些有关导入的数据(总记录、进行的记录、开始时间等)。表中的数据在导入过程中不断更新。
例如,第二个 AJAX 请求应该每 5 秒从表中获取更新的数据,并以某种通知的形式显示在页面上。
我面临的问题如下:第一个请求开始,执行它需要几分钟。与此同时,第二个请求以 5 秒的间隔被调用,但所有请求直到第一个请求完成后才会执行,它们都在排队并且状态为“Pending”。我无法弄清楚这是怎么回事。看起来我无法在第一个 TTFB 期间启动第二个 AJAX 请求。
我也尝试过使用 jQuery.when() 和 jQuery.then(),但我不明白如何在 jQuery.when() 中使用间隔进行 AJAX 调用。有什么方法可以实现我想要的功能吗?
这是我的代码,在导入按钮单击时调用 RunImport 函数:
var resultCheck, resultRun, intervalId = 0;
$(document).ready(function () {
CheckActiveImports();
});
function CheckActiveImports() {
var jqXHR = $.ajax({
url: "exhaust.aspx/GetRunningImports",
async:true,
type: "GET",
contentType: "application/json; charset=utf-8",
dataType: "json",
beforeSend: function(){
$('#output').html("Checking for running imports...");
},
success: OnCheckSuccess,
failure: function (result) {
resultCheck = "Failure: " + result.responseText;
},
error: function (result) {
resultCheck = "Error: " + result.responseText;
},
complete: function () {
$('#output').html(resultCheck);
}
});
return jqXHR;
}
function OnCheckSuccess(result)
{
var data = result.d; //JSON.parse(result).d;
if (data.length) {
var res = "";
for (var x in data) {
var format = 'Job running: ' + data[x].JobType + '. ' + data[x].Counter + ' of ' + data[x].Total + ' records processed<br /> \
Speed: ' + data[x].Speed + ' records per minute. \
Estimated time of completion: ' + data[x].EstTime + '.';
res += format;
}
resultCheck = res;
}
else {
resultCheck = 'Currently there are no jobs running.';
}
}
function RunImport()
{
intervalId = window.setInterval(CheckActiveImports, 5000);
RunImportAjax();
}
function RunImportDeferred() {
var RunImportXHR = RunImportAjax(),
CheckImportXHR = CheckActiveImports();
$.when(RunImportXHR, CheckImportXHR).then(function () {
$('#output').html(resultCheck);
$('#output2').html(resultRun);
});
}
function RunImportAjax() {
var jqXHR = $.ajax({
url: "exhaust.aspx/RunImport",
async:true,
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
beforeSend: function () {
$('#output2').html("Running import...");
},
success: function (result) {
window.clearInterval(intervalId);
var data = result.d;
if (data.length) {
var res = "";
for (var x in data) {
var format = 'Job finished: ' + data[x].JobType + '. ' + data[x].Counter + ' records processed.<br />';
res += format;
}
resultRun = res;
}
},
failure: function (result) {
resultRun = "Failure: " + result.responseText;
},
error: function (result) {
resultRun = "Error: " + result.responseText;
},
complete: function () {
$('#output2').html(resultRun);
}
});
return jqXHR;
}
【问题讨论】:
-
我做错的主要事情是调用两个 ASPX 页面(静态)网络方法。我已经将获取数据的方法从 MSSQL 表移到了 ASMX 网络服务,一切正常。
标签: javascript jquery ajax jquery-deferred deferred