Backbone.js を使用して、特定の機会に ajax ポストをクライアント Web サービスに送信する必要があるアプリケーションを作成します。
ただし、投稿されるコンテンツは動的であり、特定の配列によって決定されます。
配列内の各項目について、データを取得する必要があります。
集約オブジェクトを送信する必要があるデータを組み立てた後。
今のところ、私は同期アプローチを取っていますが、これは最善の方法ではないと感じています。
var arrParams = [{id: 1, processed: false},{id: 7, processed: false},{id: 4, processed: false}];
function callback(data) {
$.post()... // jquery ajax to post the data... }
function fetchData(arr, data, callback) {
var currentId = _(arr).find(function(p){ return p.processed === false; }).id; // getting the ID of the first param that has processed on false...
// ajax call fetching the results for that parameter.
$.ajax({
url: 'http://mysuperwebservice.com',
type: 'GET',
dataType: 'json',
data: {id: currentId},
success: function(serviceData) {
data[currentId] = serviceData; // insert it into the data
_(arr).find(function(p){ return p.id === currentId; }).processed = true; // set this param in the array to 'being processed'.
// if more params not processed, call this function again, else continue to callback
if(_(arr).any(function(p){ return p.processed === false }))
{
fetchData(arr, data, callback);
}
else
{
callback(data);
}
},
error: function(){ /* not important fr now, ... */ }
});
}
fetchData(arrParams, {}, callback);
これらの呼び出しを非同期で起動し、すべての結果が入っている場合にのみコールバックを実行する方法はありませんか?