jQuery Ajax只执行一次,但似乎每次都应该调用

目前,我已经建立了一个ajax调用,在更改特定字段时应该执行一个php脚本。 该脚本首先在页面加载时执行。

AJAX电话

$j.ajax({url: prod_json_url, dataType: 'json', cache: true, beforeSend: function( xhr ) { xhr.overrideMimeType( 'text/plain; charset=x-user-defined' ); }, success: function(data) { //things to do on success with JSON } }); 

在我的虚拟环境中,一切都很好用于测试,但是当我将其部署到不同的服务器时,会发生以下情况。

1)在页面加载时,我可以查看正在执行的FireBug中的URL并返回正确的JSON响应。 记录显示它确实转到要执行的脚本并返回正确的数据。 一切都是应有的。

2)然后我点击更新字段。 通过再次在控制台中查看Firebug,正在执行正确的URL,但JSON响应不正确。 它保持与页面加载时相同的一个。 当我添加日志记录时,它似乎从未实际到达更新的URL。 (与使用更新参数的页面加载相同的URL)。

3)如果我等待一段时间,然后再试一次,它有时会再次表现,但仅限于一次执行。

这种行为让我相信这是一个缓存问题。 有没有人知道如何解决这个或我应该寻找或检查的变量? 数据库是完全相同的,我不知道还有什么可能导致这个。 任何帮助是极大的赞赏! 如果更多信息也有帮助,请告诉我。

尝试将当前时间添加到您正在加载数据的url:

prod_json_url + '?ts=' + $.now()'

缓存控制HTML标头显然在IE中的Ajax请求上被忽略,因此不应该使用cache:false 。 这应该工作。

$.now()new Date().getTime()的快捷方式$.now() new Date().getTime() ;

将缓存设置为false。 看起来像theres客户端缓存

 $(document).ready(function() { $.ajaxSetup({ cache: false }); }); 

试试这个从limk复制