JQuery : Utilisez ceci comme point de départ - comme inspiration. J'ai résolu le problème de la façon suivante : (ce n'est pas une solution parfaite, elle abandonne juste la dernière instance et c'est du code WIP)
var singleAjax = function singleAjax_constructor(url, params) {
// remember last jQuery's get request
if (this.lastInstance) {
this.lastInstance.abort(); // triggers .always() and .fail()
this.lastInstance = false;
}
// how to use Deferred : http://api.jquery.com/category/deferred-object/
var $def = new $.Deferred();
// pass the deferrer's request handlers into the get response handlers
this.lastInstance = $.get(url, params)
.fail($def.reject) // triggers .always() and .fail()
.success($def.resolve); // triggers .always() and .done()
// return the deferrer's "control object", the promise object
return $def.promise();
}
// initiate first call
singleAjax('/ajax.php', {a: 1, b: 2})
.always(function(a,b,c) {console && console.log(a,b,c);});
// second call kills first one
singleAjax('/ajax.php', {a: 1, b: 2})
.always(function(a,b,c) {console && console.log(a,b,c);});
// here you might use .always() .fail() .success() etc.
11 votes
Duplicata possible de Supprimez les requêtes ajax en utilisant javascript en utilisant jquery.
8 votes
Votre question stipule que la requête doit avoir lieu toutes les 5 secondes, mais le code utilise 500 ms = 0,5 s.