以前很少关注这方面的问题,直达我们的技术经理找我们说要换框架,为什么换框架呢,因为缓存的问题,原来的项目是用版本号作为刷新的依据的。因为微信 公众号上有这样一个机制,使用版本好的话,有时做不到及时刷新,所以就用了vue.js,因为它有这样的功能就是如果某个文件里面的数据改变了,那么vue.js就会把这个文件的名字也相应的改掉,所以缓存里面的东西 就用不了了,这样就做到了及时刷新,向后台请求数据。

以前没有总结过js关于清除浏览器缓存的方法,今天就借此总结一下吧。

浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。

清理网站缓存的几种方法

meta方法

    <META HTTP-EQUIV="pragma" CONTENT="no-cache"> // CONTENT="no-cache" 清除缓存<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">// CONTENT="no-cache" 清除缓存<META HTTP-EQUIV="expires" CONTENT="0">

清理form表单的临时缓存 
方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:

 $.ajax({url:'www.haorooms.com',dataType:'json',data:{},beforeSend :function(xmlHttp){ xmlHttp.setRequestHeader("If-Modified-Since","0"); xmlHttp.setRequestHeader("Cache-Control","no-cache");},success:function(response){//操作 } async:false });async:false 是否异步加载。 

方法二,直接用cache:false,

 $.ajax({url:'www.haorooms.com',dataType:'json',data:{},cache:false, ifModified :true ,success:function(response){//操作}async:false});

同时关于ajax中的cache的介绍

ajax里的cache


true的话会读缓存,可能真的到服务器上。假如上次访问了a.html,第二次的时候得到的是上次访问的a.html的结果,而不是重新到服务器获取。false的话会在url后面加一个时间缀,让它跑到服务器获取结果。cache只有GET方式的时候有效。true的话会读缓存,可能真的到服务器上。假如上次访问了a.html,第二次的时候得到的是上次访问的a.html的结果,而不是重新到服务器获取。false的话会在url后面加一个时间缀,让它跑到服务器获取结果。cache只有GET方式的时候有效。
 

方法三:用随机数,随机数也是避免缓存的一种很不错的方法!

URL 参数后加上 "?ran=" + Math.random(); //当然这里参数 ran可以任意取了
eg:
<script>
document.write("<s"+"cript type='text/javascript' src='/js/test.js?"+Math.random()+"'></scr"+"ipt>"); </script> 其他的类似,只需在地址后加上+Math.random() 注意:因为Math.random() 只能在Javascript 下起作用,故只能通过Javascript的调用才可以 

使用随机数的方法就享受不到缓存带来的快速的效果了,所以只有文件更新的时候才进行才是最好的。增加随机数只是不用缓存了而已。

 

方法四:用随机时间,和随机数一样。

在 URL 参数后加上 "?timestamp=" + new Date().getTime(); 

用PHP后端清理

在服务端加 header("Cache-Control: no-cache, must-revalidate");等等(如php中)

方法五:

5、window.location.replace("WebForm1.aspx");
参数就是你要覆盖的页面,replace的原理就是用当前页面替换掉replace参数指定的页面。
这样可以防止用户点击back键。使用的是javascript脚本,举例如下:
a.html
以下是引用片段:
<html> <head> <title>a</title> <script language="javascript"> function jump(){ window.location.replace("b.html"); } </script> </head> <body> <a href="javascript:jump()">b</a> </body> </html> b.html 以下是引用片段: <html> <head> <title>b</title> <script language="javascript"> function jump(){ window.location.replace("a.html"); } </script> </head> <body> <a href="javascript:jump()">a</a> </body> </html> 

js清除浏览器缓存的几种方法(项目总结)相关推荐

  1. html js清除缓存,js清除浏览器缓存的几种方法

    JS 缓存的问题一直都是我们又爱又恨的东西.也是我们比较头痛的问题, 一方面为了提高网站响应速度,减少服务器的负担,和节省带宽,将需要将静态资源缓存在客户端, 但是另一方面,当js 文件有改动的时候, ...

  2. ajax请求时清除浏览器缓存,js清除浏览器缓存的几种方法

    JS 缓存的问题一直都是我们又爱又恨的东西.也是我们比较头痛的问题, 一方面为了提高网站响应速度,减少服务器的负担,和节省带宽,将需要将静态资源缓存在客户端, 但是另一方面,当 js 文件有改动的时候 ...

  3. js清除浏览器缓存的几种方法

    2014年9月24日 4692次浏览 关于浏览器缓存 浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能.但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数 ...

  4. 前端更新需要清空浏览器缓存_js清除浏览器缓存的几种方法

    关于浏览器缓存 浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能.但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据.像股票类网站实时更新等,这样的网站 ...

  5. JavaScript 清除浏览器缓存的几种方法

    关于浏览器缓存 浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能.但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据.像股票类网站实时更新等,这样的网站 ...

  6. 清除浏览器缓存的几种方法

    关于浏览器缓存 浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能.但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据.像股票类网站实时更新等,这样的网站 ...

  7. Android4清理代码缓存,Android清除应用缓存的两种方法

    第一种 使用ActivityManager中的clearApplicationUserData方法,代码如下: ActivityManager am = (ActivityManager) getSy ...

  8. mybatis清除一级缓存的几种方法

    1.手动清空 sqlSession.clearCache() 2.Options注解 public interface UserMapper{@Options(flushCache= Options. ...

  9. js 实现浏览器下载视频2种方法

    第一种,这种比较节能,如果视频比较大.不会造成卡顿 fetch('你的视频地址.mp4').then(res => res.blob()).then(blob => {const a = ...

最新文章

  1. 适用于CUDA GPU的Numba例子
  2. mysql中迅速插入百万条测试数据的方法
  3. 继承ViewGroup研究(汇总) 一、二、三
  4. “〜”(波浪号/波浪形/旋转)CSS选择器是什么意思?
  5. arcgis与python_Arcgis-ModelBuilder和Python学习
  6. tp5 童攀_童攀TP5企业网站实战笔记
  7. 09_ClickHouse,ReplacingMergeTree,案例,根据排序键去重,使用版本参数的去重(学习笔记)
  8. 串口UART串行总线协议
  9. mysql1033错误存储引擎_MySQL Innodb存储引擎因为缓存配置出现的错误
  10. C++ wchar_t
  11. tf.concat, np.concatenate
  12. python图像转字符画_Python实现图片转字符画的示例
  13. MTK平台TP驱动框架分析
  14. php获取字段中的第几个数字_php提取字符串中的数字
  15. 201632位matlab下载_Matlab 2016a下载
  16. UE编辑器修改背景theme
  17. 单片机24秒倒计时c语言,基于51单片机的篮球24秒倒计时器
  18. 【JAVASE】IO流基础
  19. 嵌入式设计与开发项目-DS18B20温度传感器程序设计
  20. 使用Acrobat剪切pdf文件中矢量图

热门文章

  1. iPhone用android充电头,iPhone 6s用什么充电头充电最快?安卓快充头可以混用吗?
  2. 24点纸牌游戏,c语言实现
  3. 智能化生鲜配送系统,让采购更高效
  4. 软件工程 可行性研究、系统流程图、数据流图。
  5. 国际版抖音Tik Tok怎么引流变现,卖家所不知道的那些事
  6. 如何放大图片,教您三种方法!
  7. [Ubuntu 16.04] [Memos] install ssh
  8. 计算机系统结构 之 Amdahl定律
  9. JAVA学习者从入门到精通
  10. 归并排序详解(Acwing 归并排序y总模板)