Я использую глобальные переменные для передачи ответа от вызова AJAX:
window.response = null; // most recent response from XMLHttpRequest
// the callback function for XMLHttpRequest
function userObjFromJSON() {
if (this.readyState == 4) {
var json = eval('(' + this.responseText + ')');
window.response = json;
}
else {
indicateLoading();
}
}
// loads the info for this username on the page
function loadUsernameInfo(username) {
clearPage();
getUserInfo(username);
var profile = window.response; // most recent json response (what if it hasn't come in yet?)
window.response = null;
if (profile) {
indicateLoaded(username);
fillInProfileInfo(profile);
getTweets(username);
var tweets = window.response; // most recent json response (what if it hasn't come in yet?)
if (tweets) {
fillInTweets(tweets, MAX_TWEETS);
var mentions = mentionedUsers(tweets, MAX_TWEETS);
fillInMentioned(mentions);
}
else {
indicateUnavailableTweets();
}
}
else {
indicateInvalidUsername(username);
}
}
Проблема в том, что к тому времени, когда функция контроллера хочет начать заполнять информацию, вызов AJAX еще не всегда возвращался. (Если я медленно прохожу через отладчик, он работает нормально.) Что я могу сделать, чтобы обойти это?
Я пробовал что-то вроде этого:
getUserInfo(username);
while (window.response == null); // infinite loop here
var profile = window.response; // most recent json response
Но из-за этого мой браузер не отвечает.
Я не решаюсь вызывать необходимую функцию из обратного вызова, потому что я пытаюсь реализовать модель-представление-контроллер. Вызов функции контроллера / представления из модели кажется, что это нарушило бы схему.