项目有时要用一些Ajax的效果,因为比较简单,也就没有去用什么Ajax.net之类的东西,手写代码也就实现了。、
第二天,有人向我报告错误;说是只有第一次读取的值正常,后面的值都不正常;我调试了一下 ,确实有这样的问题,查出是因为AJAX缓存的问题:解决办法有如下几种:
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:不推荐
1、加个随机数
xmlHttp.open("GET", "ajax.asp?now=" + new Date().getTime(), true);
2、在要异步获取的asp页面中写一段禁止缓存的代码:
Response.Buffer =True
Response.ExpiresAbsolute =Now() - 1
Response.Expires=0
Response.CacheControl="no-cache"
3、在ajax发送请求前加上xmlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止缓存
xmlHTTP.open("get", URL, true);
xmlHTTP.onreadystatechange = callHTML;
xmlHTTP.setRequestHeader("If-Modified-Since","0");
xmlHTTP.send();
另一个作者写到:
AJAX的缓存是由浏览器维持的,对于发向服务器的某个url,ajax仅在第一次请求时与服务器交互信息,之后的请求中,ajax不再向服务器提交请求,而是直接从缓存中提取数据。
有些情况下,我们需要每一次都从服务器得到更新后数据。思路是让每次请求的url都不同,而又不影响正常应用:在url之后加入随机内容。
e.g.
url=url+"&"+Math.random();
Key points:
1.每次请求的url都不一样(ajax的缓存便不起作用)
2.不影响正常应用(最基本的)
----------------
方法二:(未经证实)
在JSP中禁止缓存
response.addHeader("Cache-Control", "no-cache");
response.addHeader("Expires", "Thu, 01 Jan 1970 00:00:01 GMT");
HTTP:
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
<META HTTP-EQUIV="expires" CONTENT="0">
另一个作者写到:
我们都知道,ajax能提高页面载入的速度的主要原因是通过ajax减少了重复数据的载入,真正做到按需获取,既然如此,我们在写ajax程序的时候不妨送佛送到西,在客户端再做一次缓存,进一步提高数据载入速度。那就是在载入数据的同时将数据缓存在浏览器内存中,一旦数据被载入,只要页面未刷新,该数据就永远的缓存在内存中,当用户再次查看该数据时,则不需要从服务器上去获取数据,极大的降低了服务器的负载和提高了用户的体验。
分享到:
相关推荐
然而,Ajax缓存问题可能会导致一些意料之外的状况,特别是当服务器端的数据发生变化时,浏览器仍然展示旧的缓存数据,这会给用户带来困扰,甚至可能导致错误的操作。本篇文章将深入探讨Ajax缓存问题及其解决方案。 ...
### 如何不使用Ajax缓存 在Web开发中,Ajax技术因其异步通信特性而被广泛应用,但在实际项目中可能会遇到缓存问题,比如在进行数据更新操作时(如删除、修改),由于浏览器缓存的存在导致请求返回的是之前的数据...
对于IE浏览器中的AJAX缓存问题,有两种常见的解决方案: 1. **添加随机参数** 为了防止IE浏览器缓存AJAX请求的结果,可以在每次发送AJAX请求时,向URL中添加一个随机参数,通常使用当前时间戳或者随机数。这样做...
以下是对AJAX缓存问题的详尽解析。 ### AJAX缓存问题的产生 在使用AJAX进行数据请求时,浏览器为了提高性能,通常会缓存HTTP响应。这在大部分情况下是积极的,因为对于静态资源,如图片和样式表,缓存可以减少网络...
AJAX缓存机制是浏览器为了提高性能和减少网络带宽消耗而设计的一种策略。它与HTTP缓存有密切关系,但也有其独特之处。 首先,理解AJAX缓存的工作原理:当使用AJAX发送请求到服务器时,浏览器会在首次请求时与服务器...
#### 二、理解Ajax缓存机制 ##### 1. 浏览器缓存原理 当一个Ajax请求被发送到服务器后,如果请求的数据没有发生变化,浏览器会利用缓存机制来避免重复请求相同的数据,从而提高响应速度。这种缓存机制主要包括以下...
本文将深入探讨如何在AJAX(Asynchronous JavaScript and XML)与JSP(JavaServer Pages)环境中清除缓存,确保每次请求都能获取最新的数据。 ### AJAX与缓存清除 AJAX是一种在无需重新加载整个网页的情况下,能够...
然而,浏览器缓存机制有时会导致Ajax请求的数据不是最新的,这就是所谓的Ajax缓存问题。这种缓存问题会导致浏览器在发起Ajax请求时,并未向服务器请求新的数据,而是直接使用之前加载的缓存数据,从而使得获取的数据...
Ajax缓存问题通常出现在当你使用Ajax进行数据交互时,客户端(通常是浏览器)为了提高加载速度,会自动将之前请求过的资源存储在缓存中。当你再次发起相同的请求时,浏览器可能会直接从缓存中获取数据,而不是去...
但是问题来了,在FF里面,是没有ajax缓存的,也就是每次都会触发ajax请求,这点和IE不一样。所以在这里就得注意,做个判断,阻止触发ajax事件。 代码如下:function ajax_show(apartId,roomClass,sortTile){ HX_THIS...
ajax缓存有好处,但也有坏处,缓存有时候会导致误操作,影响用户体验,若你的WEB项目不需要ajax缓存功能,可按下述方法来禁止ajax缓存。 一、在ASP中禁止ajax缓存: ‘放在ASP网页最开头部分 Response.expires=0 ...
【IE下Ajax缓存问题的快速解决方法(get方式)】 在开发Web应用时,尤其是在使用Ajax技术时,可能会遇到浏览器缓存导致的问题。对于IE浏览器,由于其对GET请求的特殊处理,有时会缓存Ajax请求,从而影响到数据的实时...
总结来说,处理AJAX缓存问题的关键在于正确设置HTTP请求头,以确保浏览器始终获取最新的服务器数据。在Prototype库中,可以通过传递`requestHeaders`选项来设置这些头信息,确保每次请求都是新鲜的,不受缓存影响。...
**一、Ajax缓存问题的由来** 在默认情况下,Ajax请求会被浏览器缓存,以提高性能。但这种缓存机制有时会导致用户看到的是旧的数据,而非服务器端最新的内容。特别是在开发阶段,频繁更改服务器数据时,这个问题尤为...
解决Ajax缓存问题的方法主要有以下几种: 1. 修改IE的缓存设置:用户可以通过访问Internet选项,然后在浏览历史记录的设置中,更改Internet临时文件的选项,选择“每次访问网页时”来获取最新的内容。但这并不是...
Ajax缓存问题是指在使用Ajax技术进行网络请求时,浏览器或其他代理缓存可能会错误地返回过时的数据而不是向服务器发起新的请求。这种缓存行为可以提高应用程序的性能,但在某些情况下可能会导致数据不一致,尤其是当...
IE8和IE9是微软公司推出的两个旧版浏览器,它们存在一些特定的兼容性问题,其中Ajax缓存问题就是一例。Ajax是异步JavaScript和XML的缩写,是一种在无需重新加载整个页面的情况下,能够更新网页部分区域内容的技术。...
在本篇文章中,我们将探讨如何对 jQuery 的 AJAX 进行封装,并实现一个简单的缓存代理组件——AjaxCache。 首先,我们需要了解如何封装 jQuery 的 AJAX。以下是一个简单的示例: ```javascript define(function ...
这个问题在标题和描述中提到,即如何禁止Ajax缓存以获取程序的最新数据。以下是一些解决这个问题的方法: 1. **设置HTTP头信息**: - `If-Modified-Since`:在发送Ajax请求之前,可以设置请求头的`If-Modified-...