小编典典

如何从jQuery Ajax成功函数正确返回数组?

ajax

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);

它返回“未定义”。我不知道问题出在哪里。该数组是在成功函数中创建的,但是我无法正确返回它。谢谢你的帮助!


阅读 317

收藏
2020-07-26

共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);
});
2020-07-26