大家好,又见面了,我是你们的朋友全栈君。
以前很少关注这方面的问题,直达我们的技术经理找我们说要换框架,为什么换框架呢,因为缓存的问题,原来的项目是用版本号作为刷新的依据的。因为微信 公众号上有这样一个机制,使用版本好的话,有时做不到及时刷新,所以就用了vue.js,因为它有这样的功能就是如果某个文件里面的数据改变了,那么vue.js就会把这个文件的名字也相应的改掉,所以缓存里面的东西 就用不了了,这样就做到了及时刷新,向后台请求数据。
以前没有总结过js关于清除浏览器缓存的方法,今天就借此总结一下吧。
浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。
清理网站缓存的几种方法
meta方法
代码语言:javascript复制 <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,如下:
代码语言:javascript复制 $.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,
代码语言:javascript复制 $.ajax({
url:'www.haorooms.com', dataType:'json', data:{}, cache:false, ifModified :true , success:function(response){ //操作 } async:false });
同时关于ajax中的cache的介绍
ajax里的cache
代码语言:javascript复制true的话会读缓存,可能真的到服务器上。
假如上次访问了a.html,第二次的时候得到的是上次访问的a.html的结果,而不是重新到服务器获取。
false的话会在url后面加一个时间缀,让它跑到服务器获取结果。
cache只有GET方式的时候有效。true的话会读缓存,可能真的到服务器上。
假如上次访问了a.html,第二次的时候得到的是上次访问的a.html的结果,而不是重新到服务器获取。
false的话会在url后面加一个时间缀,让它跑到服务器获取结果。
cache只有GET方式的时候有效。
代码语言:javascript复制
方法三:用随机数,随机数也是避免缓存的一种很不错的方法!
代码语言:javascript复制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的调用才可以
使用随机数的方法就享受不到缓存带来的快速的效果了,所以只有文件更新的时候才进行才是最好的。增加随机数只是不用缓存了而已。
代码语言:javascript复制
方法四:用随机时间,和随机数一样。
代码语言:javascript复制在 URL 参数后加上 "?timestamp=" new Date().getTime();
用PHP后端清理
代码语言:javascript复制在服务端加 header("Cache-Control: no-cache, must-revalidate");等等(如php中)
方法五:
代码语言:javascript复制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>
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/161105.html原文链接:https://javaforall.cn