我使用了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'的数据类型,并将.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调用返回时将是无效的,只有在异步调用完成后才是有效的,但为时已晚,无法设置响应变量。
beforecreate
。