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 相关文章推荐
缓动函数requestAnimationFrame 更好的实现浏览器经动画
Dec 07 Javascript
node.js调用C++开发的模块实例
Jul 03 Javascript
jQuery定义插件的方法
Dec 18 Javascript
JS判断iframe是否加载完成的方法
Aug 03 Javascript
详解RequireJs官方使用教程
Oct 31 Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
Nov 11 Javascript
vue-cli中的babel配置文件.babelrc实例详解
Feb 22 Javascript
iview日期控件,双向绑定日期格式的方法
Mar 15 Javascript
ndm:NPM的桌面GUI应用程序
Oct 15 Javascript
在pycharm中开发vue的方法步骤
Mar 04 Javascript
vscode调试node.js的实现方法
Mar 22 Javascript
ES2020让代码更优美的运算符 (?.) (??)
Jan 04 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
php实现随机显示图片方法汇总
2015/05/21 PHP
Laravel5.4简单实现app接口Api Token认证方法
2019/08/29 PHP
贴一个在Mozilla中常用的Javascript代码
2007/01/09 Javascript
收藏一些不常用,但是有用的代码
2007/03/12 Javascript
javascript面向对象包装类Class封装类库剖析
2013/01/24 Javascript
利用jquery.qrcode在页面上生成二维码且支持中文
2014/02/12 Javascript
JS 打印界面的CSS居中代码适用所有浏览器
2014/03/19 Javascript
jquery的attr方法禁用表单元素禁用输入内容
2014/06/23 Javascript
使用CoffeeScrip优美方式编写javascript代码
2015/10/28 Javascript
尝试动手制作javascript放大镜效果
2015/12/25 Javascript
AngularJS 自定义指令详解及示例代码
2016/08/17 Javascript
使用vue.js实现联动效果的示例代码
2017/01/10 Javascript
使用jQuery和ajax代替iframe的方法(详解)
2017/04/12 jQuery
angular学习之从零搭建一个angular4.0项目
2017/07/10 Javascript
vue2.0.js的多级联动选择器实现方法
2018/02/09 Javascript
JavaScript私有变量实例详解
2019/01/24 Javascript
微信小程序的开发范式BeautyWe.js入门详解
2019/07/10 Javascript
javascript 数组(list)添加/删除的实现
2020/12/17 Javascript
Python中使用中文的方法
2011/02/19 Python
Python生成器定义与简单用法实例分析
2018/04/30 Python
python字符串string的内置方法实例详解
2018/05/14 Python
Python自定义装饰器原理与用法实例分析
2018/07/16 Python
Python实现字符型图片验证码识别完整过程详解
2019/05/10 Python
HTML的form表单和django的form表单
2019/07/25 Python
Macbook安装Python最新版本、GUI开发环境、图像处理、视频处理环境详解
2020/02/17 Python
Pytorch 卷积中的 Input Shape用法
2020/06/29 Python
CSS3毛玻璃效果(blur)有白边问题的解决方法
2016/11/15 HTML / CSS
马来西亚太阳镜、眼镜和隐形眼镜网上商店:Focus Point
2018/12/13 全球购物
英国婚礼商城:Wedding Mall
2019/11/02 全球购物
NHL官方在线商店:Shop.NHL.com
2020/05/01 全球购物
大学生农村教师实习自我鉴定
2013/09/21 职场文书
大学毕业寄语大全
2014/04/10 职场文书
再婚婚前财产协议书范本
2014/10/19 职场文书
财务工作检讨书
2014/10/29 职场文书
优秀班主任推荐材料
2014/12/17 职场文书
2019企业给员工的慰问信
2019/06/24 职场文书