当从 iOS 浏览器的 Back-Forward 缓存中检索页面时始终触发的事件
Posted
技术标签:
【中文标题】当从 iOS 浏览器的 Back-Forward 缓存中检索页面时始终触发的事件【英文标题】:An event that is consistently fired when the page is retrieved from the Back-Forward cache in iOS browsers 【发布时间】:2017-03-21 07:23:24 【问题描述】:当我在移动设备 (ios 10.2.1) Safari 或 Chrome 上使用后退按钮时:
窗口的页面显示事件是fired only once。 建议:1、2、3、4、5、6、7 窗口的 popstate 事件未触发。 建议:1、2、3 文档的 readystatechange 事件未触发。 建议:1我为什么需要这个?
我在点击时禁用了提交按钮,因此无法多次提交表单,但是当用户使用浏览器的后退按钮返回页面时,由于 BFCache,提交按钮保持禁用状态。
我需要一个在用户离开页面或返回页面时触发的事件,以便我可以重新启用提交按钮。 unload 事件从不触发,pagehide 和 pageshow 事件仅在第一次触发:
-
我从页面 A 导航到页面 B。
A 的页面隐藏已触发(未触发卸载)。
我使用浏览器的后退按钮返回。
A 的 pageshow 已触发(未触发 load、popstate 或 readystatechange)。
我再次导航到 B,这次没有触发 A 的页面隐藏。
我再次使用返回按钮返回,A 的 pageshow 也没有触发。
后续的后退/前进触发我找不到任何事件。
一种解决方法是在第一回刷新页面:
window.addEventListener('pageshow', function (e)
if (e.persisted)
window.location.reload();
, false);
但这违背了 BFCache 的全部意义。当使用浏览器的返回按钮而不重新加载整个页面时,是否没有可靠的方法来做一些工作?
【问题讨论】:
这个你有什么好运气吗?我仍在努力让它发挥作用。 【参考方案1】:这似乎是 Webkit 的一个已知错误: https://bugs.webkit.org/show_bug.cgi?id=156356
【讨论】:
【参考方案2】:我接受 morgoe 的回答,因为他提到的错误没有可靠的事件。
这里是绝望的解决方法: 它通过使用用户代理嗅探来检测 iOS 浏览器重新加载页面来禁用 BF 缓存。
window.addEventListener('pageshow', function (e)
e.persisted &&
/iPad|iPhone|iPod/.test(navigator.userAgent) &&
!window.MSStream &&
window.location.reload();
, false);
【讨论】:
以上是关于当从 iOS 浏览器的 Back-Forward 缓存中检索页面时始终触发的事件的主要内容,如果未能解决你的问题,请参考以下文章
仅当从 Node repl 运行代码时,Socket.IO 连接才有效
当从 iOS 中的另一个故事板场景调用 viewController 时,表视图变得空白(加载或重建)
如何设计 Web App 应用架构?「两分钟了解 IOING」
当从 UIActivityViewController 调用时,WhatsApp 在选择收件人后冻结
绝对路径访问:表示输入完整的地址进行访问 当从程序外部访问时候 例如从浏览器上访问时候 需要加上项目名称 但在代码上面访问时候 不需要加上项目名 因为已经在当前项目内了 所以不需要指定