[英]A quick question on data returned by jquery.ajax() call (EDITED)
编辑:最初的问题是由于其他地方的愚蠢语法错误,我已修复。 我有一个新问题,如下所述
我有以下jquery.ajax调用:
$.ajax({
type: 'GET',
url: servicesUrl + "/" + ID + "/tasks",
dataType: "xml",
success : createTaskListTable
});
createTaskListTable
函数定义为
function createTaskListTable(taskListXml) {
$(taskListXml).find("Task").each(function(){
alert("Found task")
}); // each task
}
问题是:这不起作用,我收到一条错误消息,说未定义taskListXml
。 JQuery文档指出,成功函数将传递三个参数,第一个是数据。
我该如何使用自己选择的变量名将.ajax()
返回的数据传递给函数。
现在的问题是,我从先前的ajax调用中获取了XML! 这怎么可能? 先前的函数定义为function convertServiceXmlDataToTable(xml)
,因此它们不使用相同的变量名。
完全困惑。 这是一些缓存问题吗? 如果是这样,如何清除浏览器缓存以摆脱早期的XML?
谢谢!
看到我的评论。 如果您使用的是IE,则会缓存GET AJAX请求。 jQuery可以通过向请求中添加一个随机的querystring变量为您解决这个问题。 只需将您的AJAX调用更改为此:
$.ajax({
type: 'GET',
url: servicesUrl + "/" + ID + "/tasks",
cache: false,
dataType: "xml",
success : createTaskListTable
});
这将自动添加随机查询字符串,从而防止浏览器缓存请求。
尝试像这样定义回调内联:
success: function createTaskListTable(data, textStatus, xhr) {
console.dir(data, textStatus, xhr);
}
如果确实将数据返回为null,那么您可能会从其他字段中获得一些见识,尤其是xhr。
请注意,错误回调使用(xhr,textStatus,errorThrown)进行调用。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.