jQuery: подождите, пока несколько запросов GET будут успешно обработаны - PullRequest
21 голосов
/ 28 марта 2012

Мне нужно отправить несколько запросов $ .get, обработать их ответы и записать результаты обработки в одном массиве. Код выглядит так:

$.get("http://mysite1", function(response){
  results[x1] = y1;
}
$.get("http://mysite2", function(response){
  results[x2] = y2;
}

// rest of the code, e.g., print results

Есть ли способ убедиться, что все функции успеха завершены, прежде чем я приступлю к остальной части своего кода?

Ответы [ 2 ]

38 голосов
/ 28 марта 2012

Существует очень элегантное решение: отложенный объект jQuery.$ .get возвращает объект jqXHR, который реализует интерфейс Deferred - эти объекты можно комбинировать следующим образом:

var d1 = $.get(...);
var d2 = $.get(...);

$.when(d1, d2).done(function() {
    // ...do stuff...
});

Подробнее в http://api.jquery.com/category/deferred-object/ и http://api.jquery.com/jQuery.when/

10 голосов
/ 28 марта 2012

$.when позволяет комбинировать несколько Deferred с (что и возвращает $.ajax).

$.when( $.get(1), $.get(2) ).done(function(results1, results2) {
    // results1 and results2 will be an array of arguments that would have been
    // passed to the normal $.get callback
}).fail(function() {
    // will be called if one (or both) requests fail.  If a request does fail,
    // the `done` callback will *not* be called even if one request succeeds.
});
...