繁体   English   中英

关于jquery.ajax()调用返回的数据的快速问题(已编辑)

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM