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复制