Как определить, когда запрос в mootools завершен?

Я новичок в moootools и создаю класс Template, это мой код -

var Template = new Class({
  Singleton : true,
  template : '',

  /* gets the component type template */
  get : function(componentType){
    var tplUrl = Core.getUrl('backend') + 'response/' + componentType + '/get_template.php',
        that = this,
        request = new Request({url: tplUrl, method : 'get',onSuccess : function(responseText){
          that.template = responseText; 
          return that;
        }}).send(); 
  }

});

Что я хочу сделать, это:

var tpl = new Template();
tpl.get('component').setTemplateData({name:'yosy'});

Проблема в том, когда я звоню этот код:

var tpl = new Template();
console.log( tpl.get('component') );

Я не получаю свой текущий объект Template, я получаю 'undefined'.
Как я могу сделать это цепным?

2 ответа

Решение

Вы делаете асинхронный вызов внутри get функция. Запрос может занять 100 мс, 1 с или 10 с и к тому времени get Функция завершается и возвращается, запрос все еще будет отложен. Вместо этого вам нужно передать функцию обратного вызова get и назовите это в случае успеха.

get: function(componentType, successCallback) {
    var request = new Request({
        ..,
        onSuccess: successCallback
    }).send();
}

Обратите внимание, что вы ничего не возвращаете из функции get. Одним из примеров способа вызвать это было бы:

tpl.get('component', function(responseText) { alert(responseText); });

В вашей функции get отсутствует возвращаемое значение. Если вы хотите, чтобы функции связывались друг с другом, вы должны вернуть сам объект

get : function(componentType){
var tplUrl = Core.getUrl('backend') + 'response/' + componentType + '/get_template.php',
    that = this,
    request = new Request({url: tplUrl, method : 'get',onSuccess : function(responseText){
      that.template = responseText; 
      return that;
    }}).send(); 

    return this;
}
Другие вопросы по тегам