Javascript如何监听页面刷新和关闭事件

在我们的何监日常生活中,时常遇到这么一种情况,听页当我们在点击一个链接、面刷关闭页面、新和表单提交时等情况,关闭会提示我们是事件否确认该操作等信息。

这里就给大家讲讲javascript的何监onbeforeunload()和onunload()两个事件。

相同点:

两者都是听页在对页面的关闭或刷新事件作个操作。

不同点:

unbeforeunload()事件执行的面刷顺序在onunload()事件之前发生。(因为,新和unbeforeunload()是关闭在页面刷新之前触发的事件,站群服务器而onubload()是事件在页面关闭之后才会触发的)。

unbeforeunload()事件可以禁止onunload()事件的何监触发。

onunload()事件是听页无法阻止页面关闭的。

浏览器的面刷兼容

onunload:

IE6,IE7,IE8 中 刷新页面、关闭浏览器之后、页面跳转之后都会执行;

IE9 刷新页面 会执行,页面跳转、关闭浏览器不能执行;

firefox(包括firefox3.6) 关闭标签之后、页面跳转之后、刷新页面之后能执行,源码下载但关闭浏览器不能执行;

Safari 刷新页面、页面跳转之后会执行,但关闭浏览器不能执行;

Opera、Chrome 任何情况都不执行。

onbeforeunload:

IE、Chrome、Safari ***支持

Firefox 不支持文字提醒信息

Opera 不支持

IE6,IE7会出现bug

示例代码:

onbeforeunload():

方式一:html元素中添加

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body onbeforeunload="return myFunction()"> <p>该实例演示了如何向 body 元素添加 "onbeforeunload" 事件。</p> <p>关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。</p> <a href="http://www.qqtimezone.top">博客地址</a>      <script> function myFunction() {      return "自定义内容"; } </script> </body> </html> 

方式二:javascript中添加

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>菜鸟教程(runoob.com)</title> </head> <body> <p>该实例演示了如何使用 HTML DOM 向 body 元素添加 "onbeforeunload" 事件。</p> <p>关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。</p> <a href="http://www.runoob.com">点击调整到菜鸟教程</a> <script> window.onbeforeunload = function(event) {      event.returnValue = "我在这写点东西..."; }; </script> </body> </html> 

方式三:添加addEventListener()事件(不过此方法IE8以下不支持)

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body> <p>该实例演示了如何使用 addEventListener() 方法向 body 元素添加 "onbeforeunload" 事件。</p> <p>关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。</p> <a href="http://www.qqtimezone.top">跳转地址</a> <script> window.addEventListener("beforeunload", function(event) {      event.returnValue = "我在这写点东西..."; }); </script> </body> </html> 

onunload():

方式一:html元素中添加

<!DOCTYPE html> <html> <head>     <title></title>     <script type="text/javascript">         function fun() {              // dosomethings         }     </script> </head> <body onunload="fun()"> </body> </html> 

方式二:javascript添加

<!DOCTYPE html> <html> <head>     <title></title>     <script type="text/javascript">     window.onunload = function() {          // dosomethings     };     </script> </head> <body> </body> </html> 

【本文为专栏作者“太平洋警察”的原创稿件,转载请通过作者获取授权】

戳这里,云服务器看该作者更多好文

IT科技类资讯
上一篇:2022年第十七届中国企业年终评选榜单揭晓:联想ST650 V2服务器荣获2022年度中国IT行业人工智能优秀产品奖
下一篇:戴尔Precision 5770移动工作站 让设计师专注创作