zoukankan      html  css  js  c++  java
  • HTML页面每次打开的时候都清除页面缓存

    解决办法为:

    (1) 用HTML标签设置HTTP头信息

    <HEAD>

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

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

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

    </HEAD>

    说明:HTTP头信息“Expires”和“Cache-Control”为应用程序服务器提供了一个控制浏览器和代理服务器上缓存的机制。HTTP头信息Expires告诉代理服务器它的缓存页面何时将过期。HTTP1.1规范中新定义的头信息Cache-Control可以通知浏览器不缓存任何页面。当点击后退按钮时,浏览器重新访问服务器已获取页面。如下是使用Cache-Control的基本方法:

      1) no-cache:强制缓存从服务器上获取新的页面

      2) no-store: 在任何环境下缓存不保存任何页面

      HTTP1.0规范中的Pragma:no-cache等同于HTTP1.1规范中的Cache-Control:no-cache,同样可以包含在头信息中。

    (2) 在需要打开的url后面增加一个随机的参数:

    增加参数前:url=test/test.jsp

    增加参数后:url=test/test.jsp?ranparam=random()

    说明:因为每次请求的url后面的参数不一样,相当于请求的是不同的页面,用这样的方法来曲线救国,清除缓存

    (3)

    chrome:

    现在新版的Chrome在developer Tools(F12调出来)的Settings(右下角有个齿轮标志)中有了个Disable cache选项。勾了便可以。

    (4)ajax方法

    方式一:用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
      });
    方法二,直接用cache:false,


     $.ajax({
         url:'www.haorooms.com',
         dataType:'json',
         data:{},
         cache:false, 
         ifModified :true ,


         success:function(response){
             //操作
         }
         async:false
      });
    (5):用随机数,随机数也是避免缓存的一种很不错的方法!


    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(); 
    (6)用PHP后端清理


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


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

    (8)添加版本号(如 layout.css?v=1)

    个人认为方法2更快,因为清除浏览器缓存还要等浏览器响应。但是每次更改版本号也很麻烦,所以需要想办法自动添加版本号,

    以下是本人收集的方法:

    方法一:可以通过js自动给html添加版本号

    1.  
      <script type="text/javascript">
    2.  
      document.write("<link rel='stylesheet' type='text/css' href='/css/layout.css?v="+new Date().getTime()+"'>");
    3.  
      </script>

    方法二:若是jsp页面,可以使用java代码生成时间戳(若是jsp页面用方法一也行,但此方法更方便)

       <link rel="stylesheet" type="text/css" href="/css/layout.css?v=<%=System.currentTimeMillis() %>">
    



    方法三:使用其他的方法添加版本号,如用node.js自动配置等

    ps:我们清除缓存的目的是为了及时看到页面的更新情况,当我们将页面上线时(即部署到正式环境,不会再做更改),建议把版本号固定,因为有缓存的页面访问更快,需要更新的时候再更换下固定版本号。

  • 相关阅读:
    MySQL数据库优化
    数据库优化
    shell使用ps -ef|grep xxx时不显示grep xxx进程的方法
    Linux:PS查看进程信息,和查看tomcat内存等信息
    neo4j在linux下的安装
    Markdown 语法整理大集合2017
    TOP 10开源的推荐系统简介
    Molecule – 帮助你构建跨平台的 HTML5 游戏
    精美照片在网页设计中的13个优秀应用案例
    开发中可能会用到的几个 jQuery 小提示和技巧
  • 原文地址:https://www.cnblogs.com/vivaxiaonan/p/9378345.html
Copyright © 2011-2022 走看看