我正在使用onbeforeunload
事件在关闭页面期间执行操作。
我不希望事件发生在Refresh
/的情况下F5。
有没有办法或其他事件来做到这一点?
我正在使用onbeforeunload
事件在关闭页面期间执行操作。
我不希望事件发生在Refresh
/的情况下F5。
有没有办法或其他事件来做到这一点?
不幸的是onbeforeunload
,事件在浏览器中监听页面状态。转到另一个页面以及刷新将更改页面状态,这意味着onbeforeunload
无论如何都会触发。
所以我认为不可能只捕捉刷新。
但是,如果您Keypress
通过 JavaScript 进行侦听和阻止,则可以实现。
刷新可以通过F5和CtrlR键完成,因此您的目标是阻止这些操作。
使用 jQuery .keydown()你可以检测到这些键码:
为了CtrlR
$(document).keydown(function (e) {
if (e.keyCode == 65 && e.ctrlKey) {
e.preventDefault();
}
});
为了 F5
$(document).keydown(function (e) {
if (e.which || e.keyCode) == 116) {
e.preventDefault();
}
});
我想在卸载前添加一个消息警报,所以我的解决方案是这个:
$(document).ready(function(){
window.onbeforeunload = PopIt;
$("a").click(function(){ window.onbeforeunload = UnPopIt; });
$(document).keydown(function(e){
if ((e.keyCode == 82 && e.ctrlKey) || (e.keyCode == 116)) {
window.onbeforeunload = UnPopIt;
}
});
});
function PopIt() { return "My message before leaving"; }
function UnPopIt() { /* nothing to return */ }
第三行($("a").click...)是为了避免在 web 部分之间导航时显示警报。