技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> JavaScript --> 控制浏览器是否缓存网页状态

控制浏览器是否缓存网页状态

浏览:2223次  出处信息

Question

    在Firefox等浏览器中,如果你打开一个页面并进行若干操作,例如在文本框进行输入,甚至点击按钮进行Ajax操作更新页面局部,这些操作的结果都会被缓存下来。在你点击链接离开这个页面后,如果你通过后退按钮回到这个页面,你会发现它仍出于你离开时的状态,而非页面刚刚加载好后的初始状态。在一些情况下,这样的缓存方式是符合我们预期的;但在另外一些情况下,我们更希望页面恢复到初始状态,或者说让页面从零开始重新加载一边。我们如何才能让浏览器尊重我们的选择呢?

Answer

    如果你只是希望页面不缓存加载后的变更,后退就恢复到最初加载的状态,你只需要一个空白的unload事件就可以了:

window.onunload = function(){};

    其中的原理是,Firefox等浏览器会尝试通过“挂起(suspend)”的方式来缓存页面,使得后退能够恢复到页面之前被挂起那一刻的状态。然而如果unload事件有处理函数,浏览器就认为你可能已经对页面进行了析构处理,这时候页面已经不可能回到正常的交互状态,也就不能以挂起的方式来缓存页面。

    如果我们希望允许浏览器挂起页面,同时又需要知道何时被挂起何时被恢复,那该怎么办呢?我们可以用window对象上的pageshow和pagehide事件。当页面被挂起并隐藏时,pagehide事件会被触发;当页面被恢复到挂起前状态并显示出来时,pageshow事件会被触发。Firefox从1.5开始就支持这两个事件,Safari最新的nightly build也支持这两个事件。

建议继续学习:

  1. 浏览器的工作原理:新式网络浏览器幕后揭秘    (阅读:19550)
  2. 浅析http协议、cookies和session机制、浏览器缓存    (阅读:15800)
  3. 分布式缓存系统 Memcached 入门    (阅读:14721)
  4. 从输入 URL 到页面加载完成的过程中都发生了什么事情?    (阅读:14502)
  5. 强制刷新本地 DNS 缓存记录    (阅读:9242)
  6. 程序员眼里IE浏览器是什么样的    (阅读:6852)
  7. 浏览器的渲染原理简介    (阅读:6389)
  8. php缓存与加速分析与汇总    (阅读:6287)
  9. 各种浏览器审查、监听http头工具介绍    (阅读:6250)
  10. 图说浏览器战争:火狐、微软、谷歌那些事    (阅读:6080)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1