解决jquery load,get 方法缓存数据问题

阅读更多
  1. 当jquery load 一个页面时候 只加载一次   解决方法有俩种   
  2. 1jQuery提供一个防止ajax使用缓存的方法,  
  3. "text/javascript" language="javascript">  
  4. $.ajaxSetup ({  
  5. cache: false //close AJAX cache  
  6. });  
  7.   
  8. 这个方法在每次load页面的时候都要执行一次  否则只会再第一次时候有效 其他load 还会读取缓存页面  
  9. 2 第二就是修改load 加载的url地址  
  10.  例如 再url 多加个时间参数就可以 这个方法再wap1.0 中 我也用过避免读取缓存  
  11.   
  12. 还有就是之前查到的其他两种办法,针对该问题,不起作用:  
  13. 1、设置html的缓存  
  14. "Pragma" CONTENT="no-cache">       
  15. "Cache-Control" CONTENT="no-cache">       
  16. "Expires" CONTENT="0">  
  17. 2、java设置缓存  
  18. <%  
  19.     request.setAttribute("decorator""none");  
  20.     response.setHeader("Cache-Control","no-cache"); //HTTP 1.1  
  21.     response.setHeader("Pragma","no-cache"); //HTTP 1.0  
  22.     response.setDateHeader ("Expires"0); //prevents caching at the proxy server  
  23. %>"code" class="java">Jquery $.get方法缓存问题  
  24.   
  25. 在ie系列下,$.get()方法在url地址固定时,会缓存返回结果,导致不可预料的问题。但在火狐下,则不会缓存。  
  26. 要解决该问题有很多办法,最直接的是把$.get()方法换成$.ajax(),然后配置cache:false即可。我不喜欢$.ajax()繁琐的配置方式,可采取以下最简单方式实现:  
  27. 在$.get()的data后面加上新的随机参数,如{data: mydata, stamp: Math.random() },由于每次数据不一样,故请求后返回的数据不会缓存。  
  28. 另外也可把$.get()改成$.post(),也可解决此问题。  
  29. 一劳永逸的解决办法是设置全局参数,$.ajaxSetup({cache:false});这样设置后,基本所有的get请求jquery都会自动加上_1948838字样的附加参数,总体来说与上面的解决方法类似。  
  30. 例如:  
  31. $.get("ProvinceListByCountryIDHandler.ashx", { "cid": $drpCountry.val(), "time"new Date().getTime() }, function(data, returnStatus) {})

你可能感兴趣的:(解决jquery load,get 方法缓存数据问题)