在這個稍微減少的代碼中,一次或多個星期的觀察結果每次從API下載一週,然後聚合爲rows
並導出爲CSV。至少這是主意。實際發生的是Uncaught (in promise) TypeError: Cannot read property 'toString' of undefined
在(未示出)exportToCsv
函數中產生,因爲_promise
從promiseArray
推到rows
即爲undefined
。我錯過了什麼?爲什麼我的承諾沒有價值?
$("#downloadBtn").click(function() {
weeks = getWeeks(startDate.val(), endDate.val()); // array like [[startDay1, endDay1], [startDay2, endDay2], ...]
// start downloading the data
var promiseArray = [];
for (i=0; i< weeks.length; i++) {
var _promise = Q.defer();
fetchDataWeek(weeks[i][0], weeks[i][1], _promise);
promiseArray.push(_promise) // Push this promise into the array
}
Promise.all(promiseArray).then(function() { // Wait for all promises to resolve
var rows = [headers];
for (i=0; i < promiseArray.length; i++) {
rows.push(promiseArray[i]);
}
exportToCsv(fileName, rows);
})
});
function fetchDataWeek(startDay, endDay, _promise) {
url = "https://api" + startDay + endDay + ".json";
$.ajax({
url: url,
success: function(result){
var weekRows = parseHistory(result);
_promise.resolve(weekRows);
},
error: function (error) {
_promise.reject(error) // rejecting it in case of error
}
});
}
// Extract all data from a query response
function parseHistory(data) {
var weekRows = [];
var days = data.history.days;
for (var i = 0; i < days.length; i++) {
dayRows = formatDay(days[i]);
for (var j= 0; j < dayRows.length; j++) {
weekRows.push(dayRows[j]);
}
}
return weekRows;
}
我認爲你的主要問題是,'_promise'是** **不承諾,但一個[遞延對象(https://github.com/kriskowal/q#using-deferreds)。你需要'promiseArray.push(_promise.promise)'。你爲什麼使用'Q' **和**原生'Promise'? – Phil
從[此答案以前的問題](http://stackoverflow.com/a/42817932/1706564)。我完全不熟悉jQuery和承諾 –