Returning data from jQuery ajax request

前端 未结 3 382
野的像风
野的像风 2021-01-13 17:24

I\'m trying to get a function to perform an ajax query and then return the interpreted JSON as an object. However for whatever reason, once this request is performed, the d

相关标签:
3条回答
  • 2021-01-13 17:44

    You need to either use a synchronous ajax request (not typical or recommended) and capture the data into a variable in the outer scope, or figure out how to manipulate the data in the callback function. The problem is that the ajax function returns before the ajax call is complete -- it's asynchronous.

    Synchronous way:

     function getCacheImage(direction) {
            var capture;
            jQuery.ajax({ 
                    url: json_request_string,
                    aSync: false,
                    success: function(data) {
                       capture = data;
                    }
            });
            return capture;
     }
    

    Typical, using callback

     function getCacheImage(direction,callback) {
    
            jQuery.ajax({ 
                    url: json_request_string,
                    success: function(data) {
                       callback( data );
                    }
            });
     }
    
     getCacheImage('left', function(data) {
          ...do something with the data...
     }
    
    0 讨论(0)
  • 2021-01-13 17:53

    You are returning the data to the code that calls the callback function. That code can not sent the data back in time so that it can be returned from the function that started the request.

    Whatever you want to do with the data, you do in the callback function.

    0 讨论(0)
  • 2021-01-13 18:07

    You can't. The first letter of the AJAX acronym stands for asynchronous, meaning that AJAX requests are sent and control is returned immediately to the calling function. What you need to do is to work with the data in the callback function.

    0 讨论(0)
提交回复
热议问题