溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

javascript如何監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件

發(fā)布時(shí)間:2021-07-01 15:49:07 來(lái)源:億速云 閱讀:1843 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了javascript如何監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

在我們的日常生活中,時(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):

  1. unbeforeunload()事件執(zhí)行的順序在onunload()事件之前發(fā)生。(因?yàn)?,unbeforeunload()是在頁(yè)面刷新之前觸發(fā)的事件,而onubload()是在頁(yè)面關(guān)閉之后才會(huì)觸發(fā)的)。

  2. unbeforeunload()事件可以禁止onunload()事件的觸發(fā)。

  3. onunload()事件是無(wú)法阻止頁(yè)面關(guān)閉的。

  4. 瀏覽器的兼容

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í)行。

javascript如何監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件

onbeforeunload:

IE、Chrome、Safari 完美支持

Firefox 不支持文字提醒信息

Opera 不支持

IE6,IE7會(huì)出現(xiàn)bug  

javascript如何監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件

示例代碼:

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 href="http://www.qqtimezone.top">博客地址</a>  
<script>
function myFunction() {
 return "自定義內(nèi)容";
}
</script>
</body>
</html>

方式二:javascript中添加

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
<p>該實(shí)例演示了如何使用 HTML DOM 向 body 元素添加 "onbeforeunload" 事件。</p>
<p>關(guān)閉當(dāng)前窗口,按下 F5 或點(diǎn)擊以下鏈接觸發(fā) onbeforeunload 事件。</p>
<a href="http://www.runoob.com">點(diǎn)擊調(diào)整到菜鳥教程</a>
<script>
window.onbeforeunload = function(event) {
 event.returnValue = "我在這寫點(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 href="http://www.qqtimezone.top">跳轉(zhuǎn)地址</a>
<script>
window.addEventListener("beforeunload", function(event) {
 event.returnValue = "我在這寫點(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>

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“javascript如何監(jiān)聽(tīng)頁(yè)面刷新和頁(yè)面關(guān)閉事件”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI