首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从ajax调用返回变量的函数

从ajax调用返回变量的函数
EN

Stack Overflow用户
提问于 2010-01-09 07:45:38
回答 3查看 3.1K关注 0票数 3

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

这是我的代码:

代码语言:javascript
运行
复制
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”。为什么会这样?我能做些什么?

谢谢。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-01-09 07:50:26

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

代码语言:javascript
运行
复制
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调用返回的变量。

票数 7
EN

Stack Overflow用户

发布于 2010-01-09 07:51:10

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

代码语言:javascript
运行
复制
function(data){  
    dataToReturn = data;  
}

直到异步AJAX调用完成后才运行。return dataToReturn实际上将在AJAX调用中的回调函数之前执行。

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

或者,将一个函数传递给GetText,以便在AJAX调用完成时执行。

票数 3
EN

Stack Overflow用户

发布于 2010-01-09 07:52:03

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2031580

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档