您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“javascript怎么監(jiān)聽頁面刷新和頁面關(guān)閉事件”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
在我們的日常生活中,時(shí)常遇到這么一種情況,當(dāng)我們?cè)邳c(diǎn)擊一個(gè)鏈接、關(guān)閉頁面、表單提交時(shí)等情況,會(huì)提示我們是否確認(rèn)該操作等信息。
這里就給大家講講javascript的onbeforeunload()和onunload()兩個(gè)事件。
相同點(diǎn):
兩者都是在對(duì)頁面的關(guān)閉或刷新事件作個(gè)操作。
不同點(diǎn):
unbeforeunload()事件執(zhí)行的順序在onunload()事件之前發(fā)生。(因?yàn)椋瑄nbeforeunload()是在頁面刷新之前觸發(fā)的事件,而onubload()是在頁面關(guān)閉之后才會(huì)觸發(fā)的)。
unbeforeunload()事件可以禁止onunload()事件的觸發(fā)。
onunload()事件是無法阻止頁面關(guān)閉的。
瀏覽器的兼容
onunload:
IE6,IE7,IE8 中 刷新頁面、關(guān)閉瀏覽器之后、頁面跳轉(zhuǎn)之后都會(huì)執(zhí)行;
IE9 刷新頁面 會(huì)執(zhí)行,頁面跳轉(zhuǎn)、關(guān)閉瀏覽器不能執(zhí)行;
firefox(包括firefox3.6) 關(guān)閉標(biāo)簽之后、頁面跳轉(zhuǎn)之后、刷新頁面之后能執(zhí)行,但關(guān)閉瀏覽器不能執(zhí)行;
Safari 刷新頁面、頁面跳轉(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 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()事件(不過此方法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>
“javascript怎么監(jiān)聽頁面刷新和頁面關(guān)閉事件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。