[英]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.