loadInfo: function(){
var jsonCounter = 0,
room = ['room1','room2','room3'],
dates = [],
prices = []
$.each(booking.rooms, function(key, room_name) {
$.getJSON('/get_info.php?room='+room_name, function(data) {
dates[room_name] = data
jsonCounter++
})
$.getJSON('/get_info.php?room='+room_name+'&prices', function(data) {
prices[room_name] = data
jsonCounter++
})
})
function checkIfReady() {
if (jsonCounter === rooms.length * 2) {
clearInterval(timer)
run_the_rest_of_the_app()
}
}
var timer = setInterval(checkIfReady, 100)
}
(クラスなどの一部なので、大幅に変更)
現時点では、タイマーの使用法がゴミのように見えるため、これは少しハックな気がします。$.when と $.done を使用しますが、部屋がいくつあるかわからないので、いつ何を入れればよいかわかりません。
run_the_rest_of_the_app() がすべての AJAX リクエストが戻ってきたときにのみ呼び出されるようにするにはどうすればよいですか?