ajax非异步请求,如何让jQuery执行同步而非异步的Ajax请求?

paulo62..

12

我使用了Carcione给出的答案并将其修改为使用JSON.

function getUrlJsonSync(url){

var jqxhr = $.ajax({

type: "GET",

url: url,

dataType: 'json',

cache: false,

async: false

});

// 'async' has to be 'false' for this to work

var response = {valid: jqxhr.statusText, data: jqxhr.responseJSON};

return response;

}

function testGetUrlJsonSync()

{

var reply = getUrlJsonSync("myurl");

if (reply.valid == 'OK')

{

console.dir(reply.data);

}

else

{

alert('not valid');

}

}

我添加了'JSON'的dataType,并将.responseText更改为responseJSON.

我还使用返回对象的statusText属性检索状态.请注意,这是Ajax响应的状态,而不是JSON是否有效.

后端必须以正确(格式良好)的JSON返回响应,否则返回的对象将是未定义的.

回答原始问题时需要考虑两个方面.一个是告诉Ajax同步执行(通过设置async:false),另一个是通过调用函数的return语句返回响应,而不是回调函数.

我也尝试过POST,但它确实有效.

我将GET更改为POST并添加了数据:postdata

function postUrlJsonSync(url, postdata){

var jqxhr = $.ajax({

type: "POST",

url: url,

data: postdata,

dataType: 'json',

cache: false,

async: false

});

// 'async' has to be 'false' for this to work

var response = {valid: jqxhr.statusText, data: jqxhr.responseJSON};

return response;

}

请注意,上述代码仅适用于async为false的情况.如果要设置async:true,则返回的对象jqxhr在AJAX调用返回时无效,仅在异步调用结束后才有效,但设置响应变量为时已晚.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值