Onunload,onbeforeunload都是在刷新或關閉時調用,能夠在<script>腳本中經過 window.onunload來指定或者在<body>裏指定。區別在於onbeforeunload在onunload以前執行,它還可 以阻止onunload的執行。html
Onbeforeunload也是在頁面刷新或關閉時調用,Onbeforeunload是正要去服務器讀 取新的頁面時調用,此時還沒開始讀取;而onunload則已經從服務器上讀到了須要加載的新的頁面,在即將替換掉當前頁面時調用。Onunload是無 法阻止頁面的更新和關閉的。而 Onbeforeunload 能夠作到。html5
一、onbeforeunload事件:
說明:目前三大主流瀏覽器中firefox和IE都支持onbeforeunload事件,opera還沒有支持。
用法:
·object.onbeforeunload = handler
·<element onbeforeunload = 「handler」 … ></element>
描述:
事件觸發的時候彈出一個有肯定和取消的對話框,肯定則離開頁面,取消則繼續待在本頁。handler能夠設一個返回值做爲該對話框的顯示文本。web
觸發於:
·關閉瀏覽器窗口
·經過地址欄或收藏夾前往其餘頁面的時候
·點擊返回,前進,刷新,主頁其中一個的時候
·點擊 一個前往其餘頁面的url鏈接的時候
·調用如下任意一個事件的時候:click,document write,document open,document close,window close ,window navigate ,window NavigateAndFind,location replace,location reload,form submit.
·當用window open打開一個頁面,並把本頁的window的名字傳給要打開的頁面的時候。
·從新賦予location.href的值的時候。
·經過input type=」submit」按鈕提交一個具備指定action的表單的時候。
能夠用在如下元素:
·BODY, FRAMESET, window
平臺支持:
IE4+/Win, Mozilla 1.7a+, Netscape 7.2+, Firefox0.9+
示例:api
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>onbeforeunload測試</title> <script> function checkLeave(){ event.returnValue="肯定離開當前頁面嗎?"; } </script> </head> <body onbeforeunload="checkLeave()"> </body> </html>
可是onbeforeunload有個小毛病,就是頁面刷新時,他仍是會調用到onbeforeunload,爲何?其實刷新就至關於關閉了這個IE再從新打開的意思,所以仍是會調用到onbeforeunload。瀏覽器
究竟怎麼解決刷新不調用onbeforeunload呢?服務器
網上提供不少方法,本人以爲最實用仍是如下這段JSapp
window.onbeforeunload = function(){ var n = window.event.screenX - window.screenLeft; var b = n > document.documentElement.scrollWidth-20; if(b && window.event.clientY < 0 || window.event.altKey) { alert("是關閉而非刷新"); window.event.returnValue = "是否關閉?"; }else{ alert("是刷新而非關閉"); } }
二、onunload事件
用法:
·object.onbeforeunload = handler
·<element onbeforeunload = "handler"></element>webapp
描述:
當用戶關閉一個頁面時觸發 onunload 事件。測試
觸發於:
·關閉瀏覽器窗口
·經過地址欄或收藏夾前往其餘頁面的時候
·點擊返回,前進,刷新,主頁其中一個的時候
·點擊 一個前往其餘頁面的url鏈接的時候
·調用如下任意一個事件的時候:click,document write,document open,document close,window close ,window navigate ,window NavigateAndFind,location replace,location reload,form submit.
·當用window open打開一個頁面,並把本頁的window的名字傳給要打開的頁面的時候。
·從新賦予location.href的值的時候。
·經過input type=」submit」按鈕提交一個具備指定action的表單的時候。
ui
示例:
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>onunload測試</title> <script> function checkLeave(){ alert("歡迎下次再來!"); } </script> </head> <body onunload="checkLeave()"> </body> </html>
參考連接:(W3C的HTML草案關於onbeforeunload的說明)
http://www.w3.org/TR/html5/webappapis.html#handler-window-onbeforeunload
(mozilla 關於onbeforeunload的說明)
https://developer.mozilla.org/zh-CN/docs/Web/API/Window/onbeforeunload
(microsoft關於beforeunload | onbeforeunload event的說明)
https://msdn.microsoft.com/en-us/library/ms536907(VS.85).aspx