jQuery ajaxSetup() 方法及ajax缓存问题

定义和用法

  • ajaxSetup() 方法为将来的 AJAX 请求设置默认值。
下面的表格中列出了可能的名称/值:

名称  值/描述
async   布尔值,表示请求是否异步处理。默认是 true。
beforeSend(xhr) 发送请求前运行的函数。
cache   布尔值,表示浏览器是否缓存被请求页面。默认是 true。
complete(xhr,status)    请求完成时运行的函数(在请求成功或失败之后均调用,即在 success 和 error 函数之后)。
contentType 发送数据到服务器时所使用的内容类型。默认是:"application/x-www-form-urlencoded"。
context 为所有 AJAX 相关的回调函数规定 "this" 值。
data    规定要发送到服务器的数据。
dataFilter(data,type)   用于处理 XMLHttpRequest 原始响应数据的函数。
dataType    预期的服务器响应的数据类型。
error(xhr,status,error) 如果请求失败要运行的函数。
global  布尔值,规定是否为请求触发全局 AJAX 事件处理程序。默认是 true。
ifModified  布尔值,规定是否仅在最后一次请求以来响应发生改变时才请求成功。默认是 false。
jsonp   在一个 jsonp 中重写回调函数的字符串。
jsonpCallback   在一个 jsonp 中规定回调函数的名称。
password    规定在 HTTP 访问认证请求中使用的密码。
processData 布尔值,规定通过请求发送的数据是否转换为查询字符串。默认是 true。
scriptCharset   规定请求的字符集。
success(result,status,xhr)  当请求成功时运行的函数。
timeout 设置本地的请求超时时间(以毫秒计)。
traditional 布尔值,规定是否使用参数序列化的传统样式。
type    规定请求的类型(GET 或 POST)。
url 规定发送请求的 URL。默认是当前页面。
username    规定在 HTTP 访问认证请求中使用的用户名。
xhr 用于创建 XMLHttpRequest 对象的函数。

其中,

$.ajaxSetup({
    cache: false
});

可以用于关闭AJAX缓存

什么是Ajax缓存原理?

Ajax在发送的数据成功后,会把请求的URL和返回的响应结果保存在缓存内,当下一次调用Ajax发送相同的请求时,它会直接从缓存中把数据取出来,这是为了提高页面的响应速度和用户体验。当前这要求两次请求URL完全相同,包括参数。这个时候,浏览器就不会与服务器交互。

Ajax缓存的好处

这种设计使客户端对一些静态页面内容的请求,比如图片,css文件,js脚本等,变得更加快捷,提高了页面的响应速度,也节省了网络通信资源。

Ajax缓存的不足

Ajax缓存虽然有上述的好处,但是如果通过Ajax对一些后台数据进行更改的时候,虽然数据在后台已经发生改变,但是页面缓存中并没有改变,对于相同的URL,Ajax提交过去以后,浏览器还只是简单的从缓存中拿数据,这种情况当然就不行了。

解决Ajax缓存问题的方法

解决这个问题最有效的办法是禁止页面缓存,有以下几种处理方法:

1、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader(“Cache-Control”,”no-cache”);

2、在服务端加 header(“Cache-Control: no-cache, must-revalidate”);

3、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader(“If-Modified-Since”,”0″);

4、在 Ajax 的 URL 参数后加上 "?fresh=" + Math.random(); //当然这里参数 fresh 可以任意取了

5、第五种方法和第四种类似,在 URL 参数后加上 "?timestamp=" + new Date().getTime();

6、用POST替代GET:不推荐

7、jQuery提供一个防止ajax使用缓存的方法:


8、修改load 加载的url地址,如在url 多加个时间参数就可以:

9、设置html的缓存



你可能感兴趣的:(jQuery ajaxSetup() 方法及ajax缓存问题)