- 
							
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条)
聪明如你,不妨在这 发表你的看法与心得 ~