JS清除IE浏览器缓存的方法


Posted in Javascript onJuly 26, 2013

js中自动清除ie缓存方法 — 常用

对于动态文件,比如 index.asp?id=... 或者 index.aspx?id=... 相信有经验的程序员都知道怎样禁止浏览器缓存数据了.
但是对于静态文件(css,jpg,gif等等), 在什么场合下面我们需要禁止浏览器缓存他们,怎么做?

方法一:Dojo中我们可以用简单的方法完成:在dojo.xhrGet(包括post)等方法中都包含preventCache属性,此属性的含义: “默认为启用浏览器缓存,否则将通过自动增加不同的参数来确保浏览器缓存失效” 我们只要把此属性赋值为:“true”即可。

方法二:document.write("
其中 ver=113 的 113就是版本号,一般都是采用 CVS 或其他工具生成的开发版本号。
这样真正做到了应该缓存的时候缓存静态文件,当版本有更新的时候从获取最新的版本,并更新缓存。
对于图像 来有效利用和更新缓存.

js清除浏览器缓存 二

为了减小浏览器与服务器之间网络传输压力,往往对静态文件,如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.

这样浏览器就会把最新的文件替换掉本地旧文件。

当然,这里还一个问题就是js必须知道服务器更新了那个js、css、图片,利用cookie和时间版本应该可以解决.

jquery自从1.2开始就有ifModified和cache参数了,不用自己加header

ifModified Boolean Default: false
Allow the request to be successful only if the response has changed since the last request. This is done by checking the Last-Modified header. Default value is false, ignoring the header.
cache Boolean Default: true
Added in jQuery 1.2, if set to false it will force the pages that you request to not be cached by the browser.

$.ajax({ 
type: "GET", 
url: "static/cache.js", 
dataType: "text", 
cache:false, 
ifModified :true 
});
Javascript 相关文章推荐
关于文本框的一些限制控制总结~~
Apr 15 Javascript
判断多个input type=file是否有已经选择好文件的代码
May 23 Javascript
编写js扩展方法判断一个数组中是否包含某个元素
Nov 08 Javascript
jquery动态加载js/css文件方法(自写小函数)
Oct 11 Javascript
浅谈document.write()输出样式
May 07 Javascript
JavaScript 栈的详解及实例代码
Jan 22 Javascript
Vue2组件tree实现无限级树形菜单
Mar 29 Javascript
JS解决移动web开发手机输入框弹出的问题
Mar 31 Javascript
详解Vue2.0里过滤器容易踩到的坑
Jun 01 Javascript
Angular中响应式表单的三种更新值方法详析
Aug 22 Javascript
vue+express+jwt持久化登录的方法
Jun 14 Javascript
在Vue中使用Echarts实例图的方法实例
Oct 10 Javascript
jquery简单的拖动效果实现原理及示例
Jul 26 #Javascript
js监听键盘事件示例代码
Jul 26 #Javascript
jQuery的控件及事件(输入控件及回车事件)使用示例
Jul 25 #Javascript
固定表格行列(expression)在IE下适用
Jul 25 #Javascript
JavaScript字符串插入、删除、替换函数使用示例
Jul 25 #Javascript
不使用浏览器运行javascript代码的方法
Jul 24 #Javascript
js展开闭合效果演示代码
Jul 24 #Javascript
You might like
re0第二季蕾姆被制作组打入冷宫!艾米莉亚女主扶正,原因唏嘘
2020/04/02 日漫
PHP的历史和优缺点
2006/10/09 PHP
用PHP读注册表
2006/10/09 PHP
php 删除数组元素
2009/01/16 PHP
yii实现级联下拉菜单的方法
2014/07/31 PHP
thinkPHP框架中执行原生SQL语句的方法
2017/10/25 PHP
Laravel中错误与异常处理的用法示例
2018/09/16 PHP
在PHP中输出JS语句以及乱码问题的解决方案
2019/02/13 PHP
彻底搞懂JS无缝滚动代码
2007/01/03 Javascript
jscript之Read an Excel Spreadsheet
2007/06/13 Javascript
jQuery之自动完成组件的深入解析
2013/06/19 Javascript
Angular2使用Angular CLI快速搭建工程(一)
2017/05/21 Javascript
JS点击缩略图整屏居中放大图片效果
2017/07/04 Javascript
JS 60秒后重新发送验证码的实例讲解
2017/07/26 Javascript
Es6 Generator函数详细解析
2018/02/24 Javascript
详解JS判断页面是在手机端还是在PC端打开的方法
2019/04/26 Javascript
TypeScript 运行时类型检查补充工具
2020/09/28 Javascript
Vue router传递参数并解决刷新页面参数丢失问题
2020/12/02 Vue.js
[42:32]完美世界DOTA2联赛循环赛 Magma vs PXG BO2第二场 10.28
2020/10/28 DOTA
Python实现简单登录验证
2016/04/13 Python
Python cookbook(数据结构与算法)字典相关计算问题示例
2018/02/18 Python
Python Learning 列表的更多操作及示例代码
2018/08/22 Python
Python multiprocessing多进程原理与应用示例
2019/02/28 Python
django 微信网页授权登陆的实现
2019/07/30 Python
python控制台实现tab补全和清屏的例子
2019/08/20 Python
python使用matplotlib:subplot绘制多个子图的示例
2020/09/24 Python
mac系统下安装pycharm、永久激活、中文汉化详细教程
2020/11/24 Python
CSS3中的Media Queries学习笔记
2016/05/23 HTML / CSS
HTML5在线预览PDF的示例代码
2017/09/14 HTML / CSS
Canvas实现放大镜效果完整案例分析(附代码)
2020/11/26 HTML / CSS
.NET笔试题(20个问题)
2016/02/02 面试题
审核会计岗位职责
2013/11/08 职场文书
学校安全教育制度
2014/01/31 职场文书
代办委托书怎样写
2014/04/08 职场文书
四风问题查摆剖析材料
2014/10/11 职场文书
导游词之太湖
2019/10/08 职场文书