javascript怎么清除缓存


本文摘自PHP中文网,作者藏色散人,侵删。

javascript清除缓存的方法:1、通过meta方法清理网站缓存;2、用ajax请求服务器最新文件,并加上请求头“If-Modified-Since”和“Cache-Control”;3、直接使用“cache:false”等等。

本文操作环境:windows7系统、javascript1.8.5版,DELL G3电脑。

JS清除缓存的几种方法

一、CSS和JS为什么带参数(形如.css?t=与.js?t=)怎样获取代码

css和js带参数(形如.css?t=与.js?t=)

使用参数有两种可能:

第一、脚本并不存在,而是服务端动态生成的,因此带了个版本号,以示区别。 即上面代码对于文件来说 等价于 但浏览器会认为他是 该文件的某个版本!

第二、客户端会缓存这些css或js文件,因此每次升级了js或css文件后,改变版本号,客户端浏览器就会重新下载新的js或css文件 ,刷性缓存的作用。

第二种情况最多,也可能两种同时存在。

版本号,可以是一个随机数,也可以是一个递增的值,大版本小版本的方式,或者根据脚本的生成时间书写,比如就是精确到了生成脚本的秒,而 2.3.3 就是大版本小版本的方式。

二、关于浏览器缓存

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

清理网站缓存的几种方法

meta方法

1

2

3

<META HTTP-EQUIV="pragma" CONTENT="no-cache">

<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">

<META HTTP-EQUIV="expires" CONTENT="0">

清理form表单的临时缓存【推荐学习:js基础教程】

方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

$.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

  });

方法二,直接用cache:false,

1

2

3

4

5

6

7

8

9

10

11

$.ajax({

     url:'www.haorooms.com',

     dataType:'json',

     data:{},

     cache:false,

     ifModified :true ,

     success:function(response){

         //操作

     }

     async:false

  });

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

URL 参数后加上 "?ran=" + Math.random(); //当然这里参数 ran可以任意取了

eg:

1

2

3

<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

以下是引用片段:

1

2

3

4

5

6

7

8

9

10

11

12

13

<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

以下是引用片段:

1

2

3

4

5

6

7

8

9

10

11

12

13

<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>

以上就是javascript怎么清除缓存的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

vue.js的select下拉框怎样绑定事件和取值

javascript怎么添加元素

js中闭包的概念

javascript怎么实现禁止缩放

手把手教你理解js中的执行上下文

javascript实现无限级递归树的代码示例

javascript背景图片怎么导入

怎么检查javascript语法错误

javascript怎么设置全选

javascript变量有几种类型

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...