【发布时间】:2013-12-30 23:57:51
【问题描述】:
我们当前的部署使用家庭构建缓存破坏方法:我们有一个映射文件,其中包含我们的 javascript 文件的哈希值(这个映射是在应用程序启动时创建的)。然后在我们的模板中使用这个文件中的值来生成一个脚本标签,其中包含一个用于缓存破坏的 GET 参数,即<script src="/static/js/somefile?v=adg34d>
我目前正在将整个页面转换为使用 RequireJS,并且我想摆脱这些缓存破坏参数,因为它们很难实现。我们的 HTTP 服务器配置为向它们服务的每个资产资源添加正确的 Last-Modified 和 ETag 标头。如果我查看 Chrome Web 控制台,我可以看到浏览器也使用它并获得正确的304。虽然我相信 Chrome 可以做到这一点,但当然还有其他浏览器。
问题是:如果我只使用 Last-Modified 和 ETag 标头可以依靠浏览器来正确处理,还是我真的需要缓存 -破坏参数?
我只需要支持:
- 歌剧
- 火狐
- 铬
- IE >= 8
- Safari >= 5
【问题讨论】:
-
使用您的原始方法,url 是不同的,您可以无限期地缓存它,知道如果它更改了 url 会更改,使用 etags 您将必须始终进行 304 检查以进行验证。如果您当前的方法使用 304,也不会发生任何变化,然后使用 ETags 会按描述工作,但是,由于请求是异步的,浏览器将经常解析为缓存。最终它会刷新(就像重新打开浏览器一样),但简单的 F5 并不总是有效。
标签: javascript http caching requirejs browser-cache