能用JS或者前端的什么方法实现清除浏览器缓存吗

 我来答
yesyes科
2020-03-20 · TA获得超过2.6万个赞
知道答主
回答量:608
采纳率:0%
帮助的人:10.1万
展开全部

可以用JS实现清除浏览器缓存,解决方法如下:

1、在静态页面也就是以.html,.jsp,.aspx,.php结尾的文件中在<dead></head>中加入以下代码。

2、如果是用ajax异步请求服务器,加上beforeSend代码。

3、或者直接将cache设为false,如图。

4、再或者是将要请求的服务器的文件,多加一个随机参数,一般为时间戳,如?ran=Math.rand();如图。


注意事项:

JavaScriptJavaScript基于对象和事件驱动并具有相对安全性的客户端脚本语言。也是一种广泛用于客户端Web开发的脚本语言,常用来给HTML网页添加动态功能,比如响应用户的各种操作。

双子孙行者
推荐于2017-08-25 · TA获得超过426个赞
知道小有建树答主
回答量:152
采纳率:100%
帮助的人:89.5万
展开全部

目的:清除浏览器缓存

浏览器缓存:有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。

使用方法:JS或者Jquery

方法一: meta方法用客户端代码使浏览器不再缓存Web页面:

<head>
<meta   http-equiv="Expires"   CONTENT="0">
<meta   http-equiv="Cache-Control"   CONTENT="no-cache">
<meta   http-equiv="Pragma"   CONTENT="no-cache">
</head>

方法二: 清理form表单的临时缓存

<body onLoad="javascript:document.yourFormName.reset()">

还可以利用jquery ajax清除浏览器缓存

方式一:用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
 });

方式二:直接用cache:false,

$.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");

以上是网上常用的清除方法,另外在java中可以通过:JAVA后端清除Session缓存方法来实现

session.removeAttribute("user");  
session.removeAttribute("constant_cache");  
session.invalidate();
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
angus_lucky
2017-05-26 · TA获得超过1307个赞
知道答主
回答量:124
采纳率:100%
帮助的人:25.4万
展开全部

为什么要清除缓存呢,如果想不缓存,每次只要带不同的时间戳就可以了

在IE或者其他的很多浏览器中,如果你每次请求的地址是相同的,浏览器就不会去连接服务器而是去读取缓存,这样对于很多应用来时是非常好的,可以降低服务器的压力或者减少带宽的使用,但是对于ajax应用,很多都是必须保持时时的连接与服务器进行交互

所以需要使用一个小技巧,时间戳来使每次的请求地址都不同,从而跳过浏览器的缓存机制实现每次的请求服务器,这样的功能在图片验证码的时候也是比较常用的一种方法

        function convertURL(url){  
            var timestmp = (new Date()).valueOf();  
            //将时间戳追加到url上面  
            url = url+ "&t=" +timestmp;  
            return url;   
        }

建议这样操作比较好,如果清理缓存,还要设置定时清理器,会比较麻烦

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
rui6ye
2017-05-13 · TA获得超过135个赞
知道答主
回答量:169
采纳率:0%
帮助的人:12.6万
展开全部
缓存都是针对具体对象的,比如图片、css、cookies、input输入项。
清楚img和css可通过前端修改文件后缀来忽略缓存,删除缓存网页是没有权限的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式