31
function ajax_test(str1){ 
  var url = "None" 
  jq.ajax({
    type:'post', 
    cache: false, 
    url: 'http://....' + str1, 
    success: function(data, status, xhr){ 
      url=data; 
    }, 
    error: function (xhr, status, e) {  
    }, 
    async: true, 
    dataType: 'json' 
  }); 
  return url 
} 

如何将全局变量设置url为返回的成功 ajax 数据?

4

2 回答 2

30

在 Javascript 中,函数不可能return产生异步结果。该函数通常会在 AJAX 请求发出之前返回。

您始终可以强制您的请求与 同步async: false,但这通常不是一个好主意,因为它会导致浏览器在等待结果时锁定。

解决这个问题的标准方法是使用回调函数。

function ajax_test(str1, callback){  
   jq.ajax({ 
     //... your options
     success: function(data, status, xhr){  
       callback(data);
     }
   });  
}  

然后你可以这样称呼它:

ajax_test("str", function(url) {
  //do something with url
});
于 2012-08-11T21:34:54.187 回答
5

这是我从 php 检索数据的示例代码,然后将值传递给 ajax 成功函数中的 javascript 全局变量。这个对我有用!

var retVal = null; 

function ajaxCallBack(retString){
    retVal = retString;
}

function readString(filename){
    $.ajax({  
        type: "POST",  
        url: "readString.php",  
        data: { 'fn': filename },      
        success: function(response){
            ajaxCallBack(response);
        }
    }); 
}

PHP 代码(readString.php):

<?php

     $fn  = $_POST['fn'];

     $file = fopen("path/".$fn.".record","r");
     $string = fread($file,filesize("path/".$fn.".record"));
     fclose($file); 

     echo $string;  
?>

但是,由于 $.ajax() 是异步发送请求的,这意味着它可能会在成功回调运行之前返回,因此您不应依赖它顺序运行并自行返回值。因此,这里我们将php响应值分配给回调函数中的全局值。

于 2014-01-15T20:59:02.660 回答