繁体   English   中英

如何/是否重写async:false AJAX函数?

[英]How/Whether to rewrite async:false AJAX function?

我正在使用带有async:false的AJAX调用来返回数据,如下所示:

var my_data = my_function(10, 20);

function my_function(value1, value2) {
    var returnData;
    $.ajax({
      type: 'POST',
      url: 'my_function.php',
      data: { variable1: value1, variable2: value2 },
      success: function(data) { returnData = data; },
      async:false
    });
    return returnData;
};

注意,我已经设置了async:false ,这在我的代码上下文中是必需的,并且可以完美地工作。

但是,在JQuery API上,此消息是为异步项提供的:

从jQuery 1.8开始,不建议使用async:false和jqXHR($ .Deferred); 您必须使用成功/错误/完成回调选项,而不要使用jqXHR对象的相应方法,例如jqXHR.done()或已弃用的jqXHR.success()。

我在理解有关我的功能的警告时遇到了麻烦,因为我没有在例程中使用$.Deferred 该警告仍然可能以我不满意的方式适用。 因此,将代码保持原样是安全的,还是应该根据不赞成使用async进行重写,如果是,则应如何重写? (我需要同步执行功能。)

非常感谢!

您提供的代码看起来不错。 以下是不推荐使用的版本(请勿这样做):

var my_data = my_function(10, 20);

function my_function(value1, value2) {
    var returnData;
    $.ajax({
      type: 'POST',
      url: 'my_function.php',
      data: { variable1: value1, variable2: value2 },
      async:false
    }).success(function(data) { returnData = data; });
   return returnData;
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM