函数从ajax调用返回变量

时间:2010-01-08 23:45:38

标签: jquery

我试图让一个函数从ajax调用中返回一个字符串。

这是我的代码:

function GetText(getThis) {  
    var current = GetMarketAndLang();  
    var dataToReturn = "Error";  
    $.get('inc/ajaxGetText.php', {lang : current.lang, market : current.market, name : getThis},  
        function(data){  
            dataToReturn = data;  
    });  
    return dataToReturn;  
}

使用firebug我可以看到ajax调用是正确的但是整个函数仍然返回文本“Error”而不是“and”。为什么这样,我该怎么办?

感谢。

3 个答案:

答案 0 :(得分:7)

这是因为AJAX查询的异步性质 - 函数在响应返回之前返回。要解决此问题,您必须使用完整的$.ajax()函数并将async设置为false

function GetText(getThis) {  
    var current = GetMarketAndLang();  
    var dataToReturn = "Error";  

    $.ajax({
        url: 'inc/ajaxGetText.php',
        type: 'GET',
        async: false,
        success: function(data) {
            dataToReturn = data;
        }
    });

    return dataToReturn;
}

这会强制脚本等待请求返回,然后脚本的执行才能继续,因此,该变量现在是从AJAX调用返回的变量。

答案 1 :(得分:3)

那是因为AJAX调用是异步的。你的

function(data){  
    dataToReturn = data;  
}
在异步AJAX调用完成之后,

才会运行。 return dataToReturn实际上将在AJAX调用中的回调函数之前执行。

执行此操作的理想方法是从回调中调用使用dataToReturn的函数。

或者将函数传递给在AJAX调用完成时执行的GetText。

答案 2 :(得分:1)

ajax调用是异步执行的,这就是为什么会立即返回“Error”的原因。要返回ajax结果,需要使用$ .ajax进行同步GET。