0

考虑:

function ajaxCall(url, callback) {
    $.ajax({
        type: "GET",
        url: url,
        success: function (data) { // <-- fail point: where does the returned data go, now?
            // do stuff with data
            if ( callback ) {
                var ret = callback();
                if ( ret !== undefined ) {
                    return ret;
                }
            }
        }
    });
}

function fooBar() {
    return ajaxCall('some/url', function () {
        // do stuff
        return some_value;
    }
}

是的,所以基本上,我想保留请求的异步性,这样浏览器就不会挂起,但最终仍会返回一个值……这是一个简化的示例,尽管我可能会进一步简化它。

事实上,我看到的唯一障碍是$.ajax它的success:匿名函数之间的转换。

哼。

4

1 回答 1

3

您不能像这样异步使用调用,回调在您的调用函数早已返回之后运行。相反,您需要做的是调用需要数据的函数作为(或整个)回调的一部分,例如:

function ajaxCall(url, callback) {
  $.ajax({
    type: "GET",
    url: url,
    success: callback
  });
}

function fooBar() {
    ajaxCall('some/url', function (data) {
        functionThatNeedsData(data);
    });
}

这只是一个展示正在发生的事情的例子,在实践中它可能只是:

function fooBar() {
  $.get('some/url', functionThatNeedsData);
}

这只是调用你的functionThatNeedsDatawhich 从请求中获取数据作为第一个参数......所以一旦服务器响应数据,你就会将它传递到它需要做的地方并使用该数据完成其余的工作。

于 2010-12-04T10:26:41.137 回答