如何在不干扰浏览器重新加载的情况下检测用户在浏览器中单击后退按钮?
Oct 22, 2024 pm 02:41 PM检测浏览器中用户的后退按钮点击
在尝试检测后退按钮点击时,开发人员通常依赖 window.onbeforeunload 事件侦听器。但是,此事件不仅会在后退按钮点击时触发,还会在浏览器重新加载时触发,这可能会产生误导。
在没有浏览器重新加载干扰的情况下检测后退按钮点击
处理单击后退按钮而没有误报,请考虑使用量身定制的方法:
-
历史记录修改:
- 页面加载时,检查是否History.pushState API 可用。
- 如果支持,使用history.pushState 将随机状态推送到历史记录中。
- 定义 onpopstate 事件监听器来处理后退和前进按钮转换。
-
基于哈希的方法:
- 如果不支持history.pushState,请使用哈希更改事件(window.onhashchange) .
- 设置初始哈希值,并在哈希更改时检查非随机哈希值。
- 使用标志来确保只有用户启动的哈希更改才会触发后退按钮逻辑,忽略浏览器重新加载。
实现
<code class="javascript">window.onload = function () { if (typeof history.pushState === "function") { history.pushState("jibberish", null, null); window.onpopstate = function () { history.pushState('newjibberish', null, null); // Handle back button click here }; } else { var ignoreHashChange = true; window.onhashchange = function () { if (!ignoreHashChange) { ignoreHashChange = true; window.location.hash = Math.random(); // Handle back button click here } else { ignoreHashChange = false; } }; } }</code>
登录后复制
兼容性
此方法据报道可以在 Chrome 和 Firefox 中有效运行。
以上是如何在不干扰浏览器重新加载的情况下检测用户在浏览器中单击后退按钮?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)