I have a procedure running on a timeout to load data in the background:
(function getSubPage() {
setTimeout(function() {
if (cnt++ < pagelist.length) {
loadSubPage(pagelist[cnt]);
getSubPage();
}
}, 500);
})();
In loadSubPage() I’m making $.ajax() calls:
function loadSubPage(page) {
if (typeof(initSubPages[page]) === "undefined") {
$.ajax({
type: "POST",
url: '/Main/GetPageData',
data: { page: page },
success: function (returndata) {
// ...
},
error: function() {
alert("Error retrieving page data.");
}
});
initSubPages[page] = true;
}
}
The problem I’m having is that the error handler is being hit when the user navigates away if any ajax requests are open. I’m trying to get around this by .stop()ing the requests on window.onbeforeunload, but I’m not sure what object to call .stop() on?
jQuery exposes the XMLHttpRequest object’s abort method so you can call it and cancel the request. You would need to store the open request into a variable and call
abort().and to stop it