-
zTree遭遇IE缓存的问题
普通类 -
- 支持
- 批判
- 提问
- 解释
- 补充
- 删除
-
-
问题描述
Ztree是比较好的目录树,但是我在实际应用中遇到了在IE下更新目录树的节点后显示却无法及时更新的情况。这样的情况在火狐和chrome中都不存在。于是尝试了好些办法,最后想到可能是缓存的问题。手动清除IE缓存后果然就正确了。但是在程序中怎么解决呢?
-
解决方法
为了减小浏览器与服务器之间网络传输压力,往往对静态文件,如js,css,修饰的图片做cache,也就是给这些文件的HTTP响应头加入 Expires和Cache-Control参数,并指定缓存时间,这样一定时间内浏览器就不会给服务器发出任何的HTTP请求(除了强制刷新),即使在 这段时间内服务器的js或css或图片文件已经更新多次,但浏览器的数据依然是原来最能初cache的旧数据,有没有办法让浏览器拿到已经修改后的最新数 据呢?
方法一:
方法是用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:
$.ajax({
type: "GET",
url: "static/cache.js",
dataType: "text",
beforeSend :function(xmlHttp){
xmlHttp.setRequestHeader("If-Modified-Since","0");
xmlHttp.setRequestHeader("Cache-Control","no-cache");}
});这里用了jquery.
这样浏览器就会把最新的文件替换掉本地旧文件。
方法二:
jquery自从1.2开始就有ifModified和cache参数了,不用自己加header
$.ajax({
type: "GET",
url: "static/cache.js",
dataType: "text",
cache:false,
ifModified :true
});方法一亲测可用,法二自己没有用过,不过貌似是一样的效果。
-
-
- 标签:
- 方法
- cache
- 文件
- 浏览器
- ztree
- 服务器
- 缓存
- 请求
- control
- ie
- 最新
- ajax
-
学习元评论 (0条)
聪明如你,不妨在这 发表你的看法与心得 ~