手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >关于捕获用户何时点击window.onbeforeunload的取消事件
关于捕获用户何时点击window.onbeforeunload的取消事件
摘要:DetectingWhenTheUserHasClickedCancelOneofthethingsyoumaywanttodoistobe...

Detecting When The User Has Clicked Cancel

One of the things you may want to do is to be notified when the user clicks cancel, aborting a page unload. Unfortunately there's no way to be immediately notified. The best you can do is to set a unique global variable in your "onbeforeunload" event and then look to see if that variable has been set in other functions. There is no way to get an immediate notification that the user has aborted a page unload.

The example code I used above to do an example of an "onbeforeunload" dialog is as follows:

复制代码 代码如下:

var _isset=0;

function demo() {

window.onbeforeunload = function () {

if (_isset==0) {

_isset=1; // This will only be seen elsewhere if the user cancels.

return "This is a demonstration, you won't leave the page whichever option you select.";

}

}

_isset=0;

window.location.reload();

return false;

}

This code defines a global variabled named _isset, and then initializes it to zero. In our "onbeforeunload" event the variable is checked and if it's set to one, no unload dialog box will appear. The only way _isset could ever be one is if the user previously aborted a page unload.

But as you can see this method won't help you if you need to be immediately notified that that the user has finished dealing with the confirmation box. You can detect when it appears on the screen but there's no way to know when the user has finished interacting with it if the user clicked cancel (if the user clicked OK, then of course the unload event will have been tripped).

--------------------------------------------------------------

虽然如此,但还是有高手给出了如下代码 ^^

复制代码 代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"

"http://www.w3.org/TR/html4/strict.dtd">

<html><head>

<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">

<meta http-equiv="Content-Style-Type" content="text/css">

<meta http-equiv="Content-Script-Type" content="text/javascript">

<title>onbeforeunload test</title>

<script type="text/javascript"><>

</script>

</head>

<body>

<h1>onbeforeunload test</h1>

</body>

</html>

复制代码 代码如下:

<script type="text/javascript">

//<![CDATA[

var

is_asked = false;

window.onbeforeunload =

function (ev) {

var e = ev || window.event;

window.focus();

if (!is_asked){

is_asked = true;

var showstr = "CUSTOM_MESSAGE";

if (e) { //for ie and firefox

e.returnValue = showstr;

}

return showstr; //for safari and chrome

}

};

window.onfocus =

function (ev){

if (is_asked){

window.location.href = "http://www.google.com";

}

}

//]]>

</script

【关于捕获用户何时点击window.onbeforeunload的取消事件】相关文章:

JavaScript的Backbone.js框架的一些使用建议整理

JavaScript实现鼠标点击后层展开效果的方法

showModelessDialog()使用详解

javascript的 {} 语句块详解

jquery滚动特效集锦

关于JavaScript作用域你想知道的一切

Javascript技术栈中的四种依赖注入小结

JS代码混淆初步

使用node+vue.js实现SPA应用

js实现字符串转日期格式的方法

精品推荐
分类导航