Подтвердить что ты не робот

Как правильно вернуть массив из функции jQuery ajax success?

TheObject = {

    getArray: function(){
        var groups = new Array;
        $.ajax({
              type: "POST",
              url: "link.php",
              success: function (data){
                  var counter = 0;
                  $('g',data).each(function(){    
                      var group_name = $(this).find("name").text();
                      var group_id = $(this).find("id").text();
                      var group = {
                         id: group_id,
                         name: group_name
                      }
                      groups[counter] = group;
                      counter++;
                  });
                  return groups;
              }
         });
     }

}

И когда я пытаюсь вызвать этот метод:

var a = TheObject.getArray();
alert(a);

Он возвращает 'undefined'. Я не могу понять, где проблема. Массив создается внутри функции успеха, но я не могу вернуть его должным образом. Спасибо за вашу помощь!

4b9b3361

Ответ 1

В вашем коде вы ищете groups с помощью процедурного кодирования после того, как был сделан ajax-вызов. Основная проблема заключается в том, что вы ищете groups до завершения вызова ajax.

Другая проблема заключается в том, что вы возвращаете группы в функцию success(), но функция TheObject.getArray() ничего не возвращает.

Итак, вам нужно включить обратный вызов в функцию ajax следующим образом:

TheObject = {
    getArray: function(callback) {
        var groups = new Array;
        $.ajax({
              type: "POST",
              url: "link.php",
              success: function (data){
                  var counter = 0;
                  $('g',data).each(function(){    
                      var group_name = $(this).find("name").text();
                      var group_id = $(this).find("id").text();
                      var group = {
                         id: group_id,
                         name: group_name
                      }
                      groups[counter] = group;
                      counter++;
                  });
                  callback.call(this,groups);
              }
         });
     }
}

TheObject.getArray(function(a) {
    // this code runs when the ajax call is complete
    alert(a);
});

Ответ 2

Очень простая версия примера Дэвида.

TheObject = {
    getArray: function(callback) { 
        $.ajax({
              cache: true,
              type: "GET",
              url: "http://www.domain.com/core/domains.php",
              success: function (data){ 
                  callback.call(this,data);
              }
         });
     }
}

TheObject.getArray(function(data) {
    javascript: console.log(data);    
});

Ответ 3

Используйте push в массиве. Также вы хотите создать тип под названием "Группа", а затем создать новую группу в цикле и затем вставить его в массив.