2017-03-07
在我們的日常生活中,時常遇到這么一種情況,當我們在點擊一個鏈接、關閉頁面、表單提交時等情況,會提示我們是否確認該操作等信息。
這里就給大家講講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元素中添加

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title></title> 6 </head> 7 <body onbeforeunload="return myFunction()"> 8 9 <p>該實例演示了如何向 body 元素添加 "onbeforeunload" 事件。</p> 10 <p>關閉當前窗口,按下 F5 或點擊以下鏈接觸發 onbeforeunload 事件。</p> 11 <a href="http://www.qqtimezone.top">博客地址</a> 12 <script> 13 function myFunction() { 14 return "自定義內容"; 15 } 16 </script> 17 18 </body> 19 </html>
方式二:javascript中添加

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>菜鳥教程(runoob.com)</title> 6 </head> 7 <body> 8 9 <p>該實例演示了如何使用 HTML DOM 向 body 元素添加 "onbeforeunload" 事件。</p> 10 <p>關閉當前窗口,按下 F5 或點擊以下鏈接觸發 onbeforeunload 事件。</p> 11 <a href="http://www.runoob.com">點擊調整到菜鳥教程</a> 12 <script> 13 window.onbeforeunload = function(event) { 14 event.returnValue = "我在這寫點東西..."; 15 }; 16 </script> 17 18 </body> 19 </html>
方式三:添加addEventListener()事件(不過此方法IE8以下不支持)

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title></title> 6 </head> 7 <body> 8 9 <p>該實例演示了如何使用 addEventListener() 方法向 body 元素添加 "onbeforeunload" 事件。</p> 10 <p>關閉當前窗口,按下 F5 或點擊以下鏈接觸發 onbeforeunload 事件。</p> 11 <a href="http://www.qqtimezone.top">跳轉地址</a> 12 <script> 13 window.addEventListener("beforeunload", function(event) { 14 event.returnValue = "我在這寫點東西..."; 15 }); 16 </script> 17 18 </body> 19 </html>
onunload():
方式一:html元素中添加

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title></title> 5 <script type="text/javascript"> 6 function fun() { 7 // dosomethings 8 } 9 </script> 10 </head> 11 <body onunload="fun()"> 12 13 </body> 14 </html>
方式二:javascript添加

1 <!DOCTYPE html> 2 <html> 3 4 <head> 5 <title></title> 6 <script type="text/javascript"> 7 window.onunload = function() { 8 // dosomethings 9 }; 10 </script> 11 </head> 12 13 <body> 14 </body> 15 16 </html>