一尘不染

如何在JavaScript中将AJAX检索的值返回到当前函数的父函数?

ajax

我有以下JavaScript(和jQuery)代码:

function checkEmail(email) {
    if (email.length) {
        $.getJSON('ajax/validate', {email: email}, function(data){
            if (data == false) {
                // stuff
            }
            return data;
        })
    }
}

我希望匿名函数return data成为父函数checkEmail()。我试图做这样的事情:

function checkEmail(email) {
    if (email.length) {
        var ret = null;
        $.getJSON('ajax/validate', {email: email}, function(data){
            if (data == false) {
                // stuff
            }
            ret = data;
        })
        return ret;
    }
}

但是,由于$.getJSON()调用是异步的,因此当然不会起作用,因此它将return ret在GET请求完成之前执行。

有什么想法吗?

谢谢!


阅读 260

收藏
2020-07-26

共1个答案

一尘不染

通常,处理此类问题的最佳方法是使用某种形式的回调函数。实际上,这实际上是唯一可行的解​​决方案-
唯一的其他选择是对浏览器自己的扩展进行编码,这要花很多钱(除非您真的很想撞墙)。这些板上实际上存在很多并行的问题:您可以尝试搜索一些,很多都是很好的。

修改代码:

function checkEmail(email) {
    /*
        original parts of the function here!
    */

    if (email.length) {
        $.getJSON('ajax/validate', {email: email}, function(data){
            if (data == false) {
                // stuff
            }
            checkEmailResponse( data );
        })
    }
}

function checkEmailResponse( data )
{
    // do something with the data.
}
2020-07-26