jquery ajax success 函数 异步调用方法中不能给全局变量赋值的原因及解决办法

Posted 番茄土豆西红柿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jquery ajax success 函数 异步调用方法中不能给全局变量赋值的原因及解决办法相关的知识,希望对你有一定的参考价值。

在调用一个jquery的ajax方法时我们有时会需要该方法返回一个值或者给某个全局变量赋值,可是我们发现程序执行完后并没有获取到我们想要的值,这时很有可能是因为你用的是ajax的异步调用async:true(默认情况),如:

function ManageCommentText(text) {
    var result = text;
    $.ajax({
        data: "get",
        url: "GetComments.aspx",
        data: "type=getText&commentText=" + text,
        cache: false,
        async: false,
        success: function (data) {
            result = data; // 注意这里不可以在前面加var 关键字
        }
    })
    return result;

以上方法是ajax的同步调用,只有在获取到了data值并赋值给result以后才会返回result完成该方法的调用。若设为async:true,
则会未等到获取data值就已经返回了result。

另一个解决办法就是将你的代码直接写到success方法里。(根据你的业务并不是所有的都可以直接写到success里的)。

以上是关于jquery ajax success 函数 异步调用方法中不能给全局变量赋值的原因及解决办法的主要内容,如果未能解决你的问题,请参考以下文章

019-JQuery(Ajax异步请求)

ajax与jQuery的异步提交,他在啥情况下会走error

javascript异步代码的回调地狱以及JQuery.deferred提供的promise解决方式

ajax,jquery,$.post/$.get异步刷新div,局部刷新页面

jQuery的ajax方法

jQuery: Deferred