我想访问某些REST URI。
$.ajax({
type: "POST",
url: url + "result/" + ticket_id,
success: function(data) {
setTimeout(function(){pollResponse(url,data.id);}, 3000);
}
});
这很有效。它访问URI,并且views函数完成它的工作。因此,在success
上,它会转移到新的URI。
function pollResponse(url, id)
{
$.getJSON(url + "status/" + id, {},
function(data) {
if (data.report == null)
{
console.log(data.status_response);
setTimeout(function(){pollResponse(url, id);}, 3000);
}
else
console.alert('DONE!');
}
);
};
如果URI没有返回report
作为数据的一部分(或为空),那么我们将在3秒后再次询问。
但是在控制台中打印日志后,响应将以[200] OK
停止。
它不再询问服务器了。
我用Python的视图功能所做的就是
from cornice import Service
status = Service(name='status',
path=root+'/status/{some_id}',
description=status_desc)
@status.get()
def get_status(request):
// do something
if (...):
return {'report': ''}
else:
return {'report': 'NOT EMPTY')
答案 0 :(得分:1)
您可能在结果或跨域问题中遇到解析问题。尝试更改代码以直接使用ajax
函数:
$.ajax({
url: url + "status/" + id,
dataType: 'json',
data: {},
success: function(data) {
if (data.report == null)
{
console.log(data.status_response);
setTimeout(function(){pollResponse(url, id);}, 3000);
}
else
console.alert('DONE!');
},
error: function(jqXHR, textStatus, errorThrown) {
console.error(textStatus);
console.error(errorThrown);
console.log(jqXHR.responseText);
}
);
通过这种方式,您可以查看响应是否导致错误。如果存在解析错误,您可以通过错误函数上的jqXHR.responseText获取数据并查看错误。
在许多情况下,jQuery中的AJAX快捷方式功能无效。这就是我很少使用它们的原因。
答案 1 :(得分:0)
看起来轮询功能中的setTimeout
应为:
setTimeout(function(){pollResponse(url, data.id);}, 3000);
而不是:
setTimeout(function(){pollResponse(url, id);}, 3000);