AJax技术

jquery ajax缓存问题解决方法小结

字号+ 作者:H5之家 来源:H5之家 2017-05-15 11:01 我要评论( )

今天在做一个ajax数据提交功能开始利用get方式一直发现提交的数据都是一样,返回的数据也很久不刷新了,这个我知道是ajax缓存问题,后来在网上整理了一些ajax缓

今天在做一个ajax数据提交功能开始利用get方式一直发现提交的数据都是一样,返回的数据也很久不刷新了,这个我知道是ajax缓存问题,后来在网上整理了一些ajax缓存问题解决方法,下面给大家分享一下。

 

解决方法:

1、给请求链接加随机数,如果用的是jQuery,直接设置: $.ajaxSetup({cache: false});

2、把type改成post,并随便设置设置一个参数data: 'a=b'(一定要设置参数,否则仍然会被cache)

3、说说生成不一样的数,就用随机数 Math.random();或者或者时间戳 + new Date();

例子

 代码如下  

$.ajax({
    type:"GET"
    url:'test.html',
    cache:false,
    dataType:"html",
    success:function(msg){
        alert(msg);
    }
});

或者

$.ajax({
    type:"GET"
    url:'test.html?'+Math.random(),
    cache:false,
    dataType:"html",
    success:function(msg){
        alert(msg);
    }
});

后来在网上找到了很多AJAX GET请求会被缓存解决方法总结一下

1、在服务端加 header(“Cache-Control: no-cache, must-revalidate”);
2、在ajax发送请求前加上 anyAjaxObj.setRequestHeader(“If-Modified-Since”,”0″);
3、在ajax发送请求前加上 anyAjaxObj.setRequestHeader(“Cache-Control”,”no-cache”);
4、在 Ajax 的 URL 参数后加上 “?fresh=” + Math.random(); //当然这里参数 fresh 可以任意取了
5、第四种方法和第三种类似,在 URL 参数后加上 “?timestamp=” + new Date().getTime();
6、用POST替代GET:不推荐

一聚小编提示您:关于ajax缓存问题我们上面的方法都有简单测试都是有效的大家根据自己喜欢选择吧,当然有时我们是需要缓存功能有时不需要大家可以根据实际情况来设置。

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 从零开始学习jQuery (六) AJAX快餐(6)

    从零开始学习jQuery (六) AJAX快餐(6)

    2017-05-17 08:04

  • AJAX教程-视频-JavaScript方向

    AJAX教程-视频-JavaScript方向

    2017-05-15 10:00

  • Javascript教程资源分享门户

    Javascript教程资源分享门户

    2017-05-15 09:09

  • 关于jQuery在Asp.Net Mvc 框架下Ajax文件上传的实现

    关于jQuery在Asp.Net Mvc 框架下Ajax文件上传的实现

    2017-05-12 17:02

网友点评