jquery是如何清除ajax缓存的
2014-07-16 11:35
337 查看
大家都知道万恶的IE在ajax中往往只读取第一次ajax请求时候的数据,其余时候都是从cache提取数据,(太懒了T_T)。原生的JS清除ajax缓存的方法多,但是终觉有点繁琐,如果是用jquery的同学,就设置一个参数就OK了,那就是cache: false,比如:
另外附上原生js方法:
my eg:
$.ajax({ url: "mms-draft!getMmsDraftList", cache: false, dataType : "json", data:{ //some parameters }, success: function(data) { //do something } });
另外附上原生js方法:
1、在服务端加 header("Cache-Control: no-cache, must-revalidate");(如php中) 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:不推荐
my eg:
//创建测试用户是否存在的方法 function MatchBM() { userName= document.getElementById("ctl00_ContentPlaceHolder1_baoming1_txtUserName"); passWord = document.getElementById("ctl00_ContentPlaceHolder1_baoming1_txtPassWord"); var strUserName = enCode(userName.value); createXMLHttpRequest(); //创建XMLHttpRequest对象 try { xmlHttp.onreadystatechange = UserIsExist; //指定判断当前输入的用户是否已经存在的方法名 xmlHttp.open("GET", "MatchBaoming.aspx?txtUserName="+strUserName+"&txtPassWord="+passWord.value+"&fresh=" + Math.random(), true); // true:允许异步请求 xmlHttp.send(null); //发送上面创建的HTTP请求 } catch (exception) { alert("您要访问的资源不存在!"); } }
相关文章推荐
- 你清楚jquery是如何清除ajax缓存的吗?
- jquery之清除ajax缓存
- IE下清除AJAX弹出层的缓存,Jquery
- jquery中清除ajax缓存方法
- 【jquery教程】如何禁用jquery ajax缓存?ajaxSetup方法设置ajax默认选项
- jQuery validate 如何清除remote验证的缓存 (在select验证时这个bug尤为明显)
- 【JQuery-01】JQuery-Ajax请求在IE中清除缓存
- 如何清除浏览器的缓存以达到不让别人从缓存中偷取网页资料?
- 如何清除web 服务器的缓存
- 如何清除web 服务器的缓存
- 防止jQuery ajax load()禁用缓存
- ajax应用中如何禁止缓存
- 如何实现jQuery的Ajax文件上传
- 如何去除AJAX取过值后IE的缓存/取得xmlHttp.status状态时为空/在AJAX中如何传递中文
- 如何清除浏览器的缓存
- DIV教程之如何使div居中(垂直水平居中)(转载于www.jqueryajax.com)
- 如何使用.NET清除IE的缓存(Temporary Internet Files)
- ajax清除缓存方法
- 如何清除aspx网页中的flash缓存
- 如何清除tomcat缓存