禁止js文件缓存方法举例(js自动清除缓存)

本文目录一览:

如何清除在浏览器 中的js缓存文件

关于浏览器缓存

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

清理网站缓存的几种方法

meta方法

?

1

2

3

4

//不缓存

META HTTP-EQUIV=”pragma” CONTENT=”no-cache”

META HTTP-EQUIV=”Cache-Control” CONTENT=”no-cache, must-revalidate”

META HTTP-EQUIV=”expires” CONTENT=”0″

清理form表单的临时缓存

body onLoad=”javascript:document.yourFormName.reset()”

其实form表单的缓存对于我们书写还是有帮助的,一般情况不建议清理,但是有时候为了安全问题等,需要清理一下!

jquery ajax清除浏览器缓存

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

$.ajax({

url:”,

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:”,

dataType:’json’,

data:{},

cache:false,

ifModified :true ,

success:function(response){

//操作

}

async:false

});

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

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

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

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

用php后端清理

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

方法五:

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

titlea/title

script language=”javascript”

function jump(){

window.location.replace(“b.html”);

}

/script

/head

body

a href=”javascript:jump()” rel=”external nofollow” rel=”external nofollow” b/a

/body

/html

b.html

以下是引用片段:

如何防止js和css缓存

解决办法一:每次修改js或css文件后,都要手工修改那个版本号,注意:是每修改一次(哪怕仅仅是改了一个字符)都要修改版本号;

解决办法二:如果嫌手工修改太麻烦,那可以通过程序来自动修改(用随机数做版本号)。如果你的网站是动态的,那可以通过后台程序来改,比如ASP的:

link rel=”stylesheet” href=”static/mimi/css/main.css?v=%=rnd()%” type=”text/css”/

PHP的:

link rel=”stylesheet” href=”static/mimi/css/main.css?v=?php echo mt_rand(); ?” type=”text/css”/

如果是静态网站那就要js脚本来实现了,这个稍微麻烦点,这里就不说了。

其实上述方法一和方法二的目的都是为了使每次打开的js或css的url不同,这样浏览器就不会去缓存区取数据,而是直接到网站下载。

如果上述方法仍然无效,那就是你的浏览器的缓存机制存在问题,比如“从不检查网页的新版本,除非手动刷新”,这个就要你自己去设置了。

js缓存怎样清理

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

清理网站缓存的几种方法

meta方法

META HTTP-EQUIV=”pragma” CONTENT=”no-cache” 

META HTTP-EQUIV=”Cache-Control” CONTENT=”no-cache, must-revalidate” 

META HTTP-EQUIV=”expires” CONTENT=”0″123

清理form表单的临时缓存 

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

 $.ajax({

     url:”,

     dataType:’json’,

     data:{},

     beforeSend :function(xmlHttp){ 

        xmlHttp.setRequestHeader(“If-Modified-Since”,”0″); 

        xmlHttp.setRequestHeader(“Cache-Control”,”no-cache”);

     },

     success:function(response){

         //操作

     }

     async:false

  });12345678910111213

方法二,直接用cache:false,

 $.ajax({

     url:”,

     dataType:’json’,

     data:{},

     cache:false, 

     ifModified :true ,

     success:function(response){

         //操作

     }

     async:false

  });123456789101112

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

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的调用才可以 12345678

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

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

用php后端清理

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

方法五:

5、window.location.replace(“WebForm1.aspx”);   

参数就是你要覆盖的页面,replace的原理就是用当前页面替换掉replace参数指定的页面。   

这样可以防止用户点击back键。使用的是javascript脚本,举例如下: 

a.html 

以下是引用片段: 

html 

     head 

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

         titleb/title      

         script language=”javascript” 

             function jump(){ 

                 window.location.replace(“a.html”); 

             } 

         /script 

     /head 

     body 

        a href=”javascript:jump()”a/a 

    /body 

/html

js缓存问题怎么解决

有时候在更改js文件后,页面并没有及时显示出来,可能由于修改的文件不对,或者存在缓存问题。

面对的缓存问题有两个:

一是页面引入的js文件缓存。

二是js请求后台的缓存。

解决方法:

对于第一种情况,有两种处理方式:1、可以在页面引入的js文件后面增加日趋,如果不经常改动的文件,可以在每次改动后修改后缀。script type=”text/javascript” src=”scripts/jquery-1.5.2.min.js?version=1″/script

2、修改js文件的名字,如script type=”text/javascript” src=”scripts/jquery.js”/script

对于第二种情况,一般的处理方式是在请求的路径后面加上毫秒值,这样每次请求的路径都不一样,但是对于后台来说都是一样的,用来欺骗浏览器,进行实时请求,不调用浏览器缓存。

原创文章,作者:EWLOA,如若转载,请注明出处:https://www.506064.com/n/313645.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
EWLOAEWLOA
上一篇 2025-01-07 09:44
下一篇 2025-01-07 09:44

相关推荐

  • JS Proxy(array)用法介绍

    JS Proxy(array)可以说是ES6中非常重要的一个特性,它可以代理一个数组,监听数据变化并进行拦截、处理。在实际开发中,使用Proxy(array)可以方便地实现数据的监…

    编程 2025-04-29
  • ArcGIS更改标注位置为中心的方法

    本篇文章将从多个方面详细阐述如何在ArcGIS中更改标注位置为中心。让我们一步步来看。 一、禁止标注智能调整 在ArcMap中设置标注智能调整可以自动将标注位置调整到最佳显示位置。…

    编程 2025-04-29
  • vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常问题的解决

    本文旨在解决vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常的问题,提供完整的代码示例供参考。 一、分析问题 首先,需了解vue中下载文件的情况。一般情况下,我们…

    编程 2025-04-29
  • 解决.net 6.0运行闪退的方法

    如果你正在使用.net 6.0开发应用程序,可能会遇到程序闪退的情况。这篇文章将从多个方面为你解决这个问题。 一、代码问题 代码问题是导致.net 6.0程序闪退的主要原因之一。首…

    编程 2025-04-29
  • Python创建分配内存的方法

    在python中,我们常常需要创建并分配内存来存储数据。不同的类型和数据结构可能需要不同的方法来分配内存。本文将从多个方面介绍Python创建分配内存的方法,包括列表、元组、字典、…

    编程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件并生成完整的图像

    OBJ格式是一种用于表示3D对象的标准格式,通常由一组顶点、面和纹理映射坐标组成。在本文中,我们将讨论如何将多个OBJ文件拼接在一起,生成一个完整的3D模型。 一、读取OBJ文件 …

    编程 2025-04-29
  • Python中init方法的作用及使用方法

    Python中的init方法是一个类的构造函数,在创建对象时被调用。在本篇文章中,我们将从多个方面详细讨论init方法的作用,使用方法以及注意点。 一、定义init方法 在Pyth…

    编程 2025-04-29
  • 使用Vue实现前端AES加密并输出为十六进制的方法

    在前端开发中,数据传输的安全性问题十分重要,其中一种保护数据安全的方式是加密。本文将会介绍如何使用Vue框架实现前端AES加密并将加密结果输出为十六进制。 一、AES加密介绍 AE…

    编程 2025-04-29
  • 为什么用cmd运行Java时需要在文件内打开cmd为中心

    在Java开发中,我们经常会使用cmd在命令行窗口运行程序。然而,有时候我们会发现,在运行Java程序时,需要在文件内打开cmd为中心,这让很多开发者感到疑惑,那么,为什么会出现这…

    编程 2025-04-29
  • 用不同的方法求素数

    素数是指只能被1和自身整除的正整数,如2、3、5、7、11、13等。素数在密码学、计算机科学、数学、物理等领域都有着广泛的应用。本文将介绍几种常见的求素数的方法,包括暴力枚举法、埃…

    编程 2025-04-29

发表回复

登录后才能评论