javascript監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件方法詳解
在我們的日常生活中,時(shí)常遇到這么一種情況,當(dāng)我們?cè)邳c(diǎn)擊一個(gè)鏈接、關(guān)閉頁(yè)面、表單提交時(shí)等情況,會(huì)提示我們是否確認(rèn)該操作等信息。
這里就給大家講講javascript的onbeforeunload()和onunload()兩個(gè)事件。
相同點(diǎn):
兩者都是在對(duì)頁(yè)面的關(guān)閉或刷新事件作個(gè)操作。
不同點(diǎn):
- unbeforeunload()事件執(zhí)行的順序在onunload()事件之前發(fā)生。(因?yàn)椋瑄nbeforeunload()是在頁(yè)面刷新之前觸發(fā)的事件,而onubload()是在頁(yè)面關(guān)閉之后才會(huì)觸發(fā)的)。
- unbeforeunload()事件可以禁止onunload()事件的觸發(fā)。
- onunload()事件是無(wú)法阻止頁(yè)面關(guān)閉的。
- 瀏覽器的兼容
onunload:
IE6,IE7,IE8 中 刷新頁(yè)面、關(guān)閉瀏覽器之后、頁(yè)面跳轉(zhuǎn)之后都會(huì)執(zhí)行;
IE9 刷新頁(yè)面 會(huì)執(zhí)行,頁(yè)面跳轉(zhuǎn)、關(guān)閉瀏覽器不能執(zhí)行;
firefox(包括firefox3.6) 關(guān)閉標(biāo)簽之后、頁(yè)面跳轉(zhuǎn)之后、刷新頁(yè)面之后能執(zhí)行,但關(guān)閉瀏覽器不能執(zhí)行;
Safari 刷新頁(yè)面、頁(yè)面跳轉(zhuǎn)之后會(huì)執(zhí)行,但關(guān)閉瀏覽器不能執(zhí)行;
Opera、Chrome 任何情況都不執(zhí)行。

onbeforeunload:
IE、Chrome、Safari 完美支持
Firefox 不支持文字提醒信息
Opera 不支持
IE6,IE7會(huì)出現(xiàn)bug

示例代碼:
onbeforeunload():
方式一:html元素中添加
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body onbeforeunload="return myFunction()">
<p>該實(shí)例演示了如何向 body 元素添加 "onbeforeunload" 事件。</p>
<p>關(guān)閉當(dāng)前窗口,按下 F5 或點(diǎn)擊以下鏈接觸發(fā) onbeforeunload 事件。</p>
<a >博客地址</a>
<script>
function myFunction() {
return "自定義內(nèi)容";
}
</script>
</body>
</html>
方式二:javascript中添加
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(runoob.com)</title>
</head>
<body>
<p>該實(shí)例演示了如何使用 HTML DOM 向 body 元素添加 "onbeforeunload" 事件。</p>
<p>關(guān)閉當(dāng)前窗口,按下 F5 或點(diǎn)擊以下鏈接觸發(fā) onbeforeunload 事件。</p>
<a >點(diǎn)擊調(diào)整到菜鳥(niǎo)教程</a>
<script>
window.onbeforeunload = function(event) {
event.returnValue = "我在這寫(xiě)點(diǎn)東西...";
};
</script>
</body>
</html>
方式三:添加addEventListener()事件(不過(guò)此方法IE8以下不支持)
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<p>該實(shí)例演示了如何使用 addEventListener() 方法向 body 元素添加 "onbeforeunload" 事件。</p>
<p>關(guān)閉當(dāng)前窗口,按下 F5 或點(diǎn)擊以下鏈接觸發(fā) onbeforeunload 事件。</p>
<a >跳轉(zhuǎn)地址</a>
<script>
window.addEventListener("beforeunload", function(event) {
event.returnValue = "我在這寫(xiě)點(diǎn)東西...";
});
</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>
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)數(shù)組扁平化的方法分享
數(shù)組扁平化指的是:將一個(gè)多層嵌套的數(shù)組,處理成只有一層的數(shù)組。本文主要和大家介紹了幾個(gè)常用的JS數(shù)組扁平化方法,希望對(duì)大家有所幫助2023-04-04
JavaScript腳本性能優(yōu)化注意事項(xiàng)
本文總結(jié)了我在JavaScript編程中所找到的提高JavaScript運(yùn)行性能的一些方法,其實(shí)這些經(jīng)驗(yàn)都基于幾條原則2008-11-11
JavaScript對(duì)象訪問(wèn)器的工作原理及使用方法
今天來(lái)聊一下JavaScript中的對(duì)象訪問(wèn)器,JavaScript的主要功能之一是能夠定義對(duì)象,這些對(duì)象可以封裝屬性和方法,本文將深入探討 JavaScript 對(duì)象訪問(wèn)器是什么、它是如何工作的以及使用對(duì)象訪問(wèn)器的作用,需要的朋友可以參考下2024-06-06
實(shí)現(xiàn)圖片首尾平滑輪播(JS原生方法—節(jié)流)
下面小編就為大家?guī)?lái)一篇實(shí)現(xiàn)圖片首尾平滑輪播(JS原生方法—節(jié)流)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
JavaScript用Number方法實(shí)現(xiàn)string轉(zhuǎn)int
parseInt方法在format'00'開(kāi)頭的數(shù)字時(shí)會(huì)當(dāng)作2進(jìn)制轉(zhuǎn)10進(jìn)制,所以建議string轉(zhuǎn)int最好用Number方法2014-05-05
JavaScript利用crypto模塊實(shí)現(xiàn)加解密
crypto模塊提供了加密功能,包含對(duì) OpenSSL 的哈希、HMAC、加密、解密、簽名、以及驗(yàn)證功能的一整套封裝。本文將利用它實(shí)現(xiàn)加解密算法,需要的可以參考一下2023-02-02
JavaScript動(dòng)畫(huà)函數(shù)封裝詳解
動(dòng)畫(huà)的原理是通過(guò)定時(shí)器setInterval() 不斷移動(dòng)盒子位置。但是如果同時(shí)有好幾個(gè)元素都需要添加動(dòng)畫(huà)呢?我們就可以考慮將其封裝成一個(gè)簡(jiǎn)單的動(dòng)畫(huà)函數(shù)。本文將為大家介紹如何進(jìn)行封裝,需要的可以參考一下2021-12-12
JavaScript面向?qū)ο罄^承原理與實(shí)現(xiàn)方法分析
這篇文章主要介紹了JavaScript面向?qū)ο罄^承原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析就面向?qū)ο蟪绦蛟O(shè)計(jì)中原形、對(duì)象、繼承的相關(guān)概念、原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2018-08-08

