$.ajax 等待执行,jquery ajax同步调用(当前线程上的执行需要等待)

更好的方法是使用jQuery Promises。这样的事情可以奏效:

var ajaxRequest = function () {

var deferred = $.Deferred();

$.ajax({

type: "POST",

url: "/service/save.php",

data: dataString,

success: function (result) {

// This will fire the done function

deferred.resolve(result);

},

error: function (xhr, status, errorThrown) {

// This will fire the fail function

deferred.reject(xhr, status, errorThrown);

}

});

return deferred.promise();

};

var somefunction = function () {

// This will return a promise

var getSomeData = ajaxRequest();

// The appropriate function will be called based on if the promise is resolved or rejected through the success and error functions in the AJAX request

getSomeData.then(

// Done response

function (result) {

alert("Success!");

// Enter logic here to handle the data which you have waited for

},

// Fail response

function (xhr, status, errorThrown) {

// Handle errors here...

}

);

};

somefunction();

如果你愿意,这个方法还允许你重用ajaxRequest函数并以不同的方式处理结果!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值