基于JavaScript判斷瀏覽器到底是關(guān)閉還是刷新(超準(zhǔn)確)
本文是小編總結(jié)的一些核心內(nèi)容,個(gè)人感覺對大家有所幫助,具體內(nèi)容請看下文:
頁面加載時(shí)只執(zhí)行onload
頁面關(guān)閉時(shí)只執(zhí)行onunload
頁面刷新時(shí)先執(zhí)行onbeforeunload,然后onunload,最后onload。
經(jīng)過驗(yàn)證我得出的結(jié)論是:
//對于ie,谷歌,360:
//頁面加載時(shí)只執(zhí)行onload
//頁面刷新時(shí),刷新之前執(zhí)行onbeforeunload事件,在新頁面即將替換舊頁面時(shí)onunload事件,最后onload事件。
//頁面關(guān)閉時(shí),先onbeforeunload事件,再onunload事件。
//對于火狐:
//頁面刷新時(shí),只執(zhí)行onunload;頁面關(guān)閉時(shí),只執(zhí)行onbeforeunload事件
那么回歸正題,到底怎樣判斷瀏覽器是關(guān)閉還是刷新?我按照網(wǎng)上的各種說法實(shí)驗(yàn)千百遍,都未成功,其中各種說法如下:
window.onbeforeunload = function() //author: meizz
{
var n = window.event.screenX - window.screenLeft;
var b = n > document.documentElement.scrollWidth-20;
if(b && window.event.clientY < 0 || window.event.altKey)
{
alert("是關(guān)閉而非刷新");
window.event.returnValue = ""; //這里可以放置你想做的操作代碼
}else
{
alert("是刷新而非關(guān)閉");
}
}
window.onbeforeunload = function() //author: meizz
{
var n = window.event.screenX - window.screenLeft;
var b = n > document.documentElement.scrollWidth-20;
if(b && window.event.clientY < 0 || window.event.altKey)
{
alert("是關(guān)閉而非刷新");
window.event.returnValue = ""; //這里可以放置你想做的操作代碼
}else
{
alert("是刷新而非關(guān)閉");
}
}
和
function CloseOpen(event) {
if(event.clientX<=0 && event.clientY<0) {
alert("關(guān)閉");
}
else
{
alert("刷新或離開");
}
}
</script>
<body onunload="CloseOpen(event)">
..........................
這些方法都不管用,但是我并沒有放棄,想啊想啊........
按照上面我得出結(jié)論,
//對于ie,谷歌,360:
//頁面加載時(shí)只執(zhí)行onload
//頁面刷新時(shí),刷新之前執(zhí)行onbeforeunload事件,在新頁面即將替換舊頁面時(shí)onunload事件,最后onload事件。
//頁面關(guān)閉時(shí),先onbeforeunload事件,再onunload事件。
//對于火狐:
//頁面刷新時(shí),只執(zhí)行onunload;頁面關(guān)閉時(shí),只執(zhí)行onbeforeunload事件
刷新的時(shí)候先onbeforeunload,然后取服務(wù)端請求數(shù)據(jù),在新頁面即將替換舊頁面時(shí)onunload事件,而頁面關(guān)閉時(shí),先onbeforeunload事件,再立即onunload事件。那么在刷新的時(shí)候,onbeforeunload與onunload之間的時(shí)間肯定比關(guān)閉的時(shí)候時(shí)間長,經(jīng)過測試確實(shí)如此。
貼出我的測試代碼:
var _beforeUnload_time = 0, _gap_time = 0;
var is_fireFox = navigator.userAgent.indexOf("Firefox")>-1;//是否是火狐瀏覽器
window.onunload = function (){
_gap_time = new Date().getTime() - _beforeUnload_time;
if(_gap_time <= 5)
$.post(pathName+"/back/bi!aaaa.s2?t="+_beforeUnload_time,{msg:"瀏覽器關(guān)閉",time:_gap_time},function(json){},"text");
else
$.post(pathName+"/back/bi!aaaa.s2?t="+_beforeUnload_time,{msg:"瀏覽器刷新",time:_gap_time},function(json){},"text");
}
window.onbeforeunload = function (){
_beforeUnload_time = new Date().getTime();
if(is_fireFox)//火狐關(guān)閉執(zhí)行
$.post(pathName+"/back/bi!aaaa.s2?t="+_beforeUnload_time,{msg:"火狐關(guān)閉"},function(json){},"text");
};
服務(wù)端代碼(SSH實(shí)現(xiàn)):
public void aaaa(){
System.out.println(base.getParameter("msg")+",間隔:"+base.getParameter("time"));
}
對于if(_gap_time <= 5),此處的5是我預(yù)設(shè)的,按照客戶端瀏覽器而定,也與客戶端的機(jī)器配置有關(guān)系,我的機(jī)器關(guān)閉瀏覽器時(shí)onbeforeunload事件與onunload事件的數(shù)據(jù)間隔不超過2ms,而刷新時(shí)的間隔100%大于2ms,因?yàn)橐L問服務(wù)器。下面貼出我的測試結(jié)果:

下面給大家介紹瀏覽器關(guān)閉監(jiān)聽事件,判斷刷新還是關(guān)閉
使用onunload或onbeforeunload可以監(jiān)聽瀏覽器關(guān)閉事件,但是無法區(qū)分關(guān)閉與刷新。以下js代碼可以部分監(jiān)聽關(guān)閉瀏覽器的事件!
//鼠標(biāo)相對于用戶屏幕的水平位置 - 窗口左上角相對于屏幕左上角的水平位置 = 鼠標(biāo)在當(dāng)前窗口上的水平位置
var n = window.event.screenX - window.screenLeft;
//鼠標(biāo)在當(dāng)前窗口內(nèi)時(shí),n<m,b為false;鼠標(biāo)在當(dāng)前窗口外時(shí),n>m,b為true。20這個(gè)值是指關(guān)閉按鈕的寬度
var b = n > document.documentElement.scrollWidth-20;
//鼠標(biāo)在客戶區(qū)內(nèi)時(shí),window.event.clientY>0;鼠標(biāo)在客戶區(qū)外時(shí),window.event.clientY<0
if(b && window.event.clientY < 0 || window.event.altKey || window.event.ctrlKey){
關(guān)閉瀏覽器時(shí)你想做的事
}else if(event.clientY > document.body.clientHeight || event.altKey){
關(guān)閉瀏覽器時(shí)你想做的事
}
這段js能監(jiān)聽到鼠標(biāo)點(diǎn)擊瀏覽器關(guān)閉按鈕、瀏覽器狀態(tài)欄鼠標(biāo)右鍵彈出菜單中的關(guān)閉以及各種快捷鍵。但是雙擊瀏覽器坐上角圖標(biāo)關(guān)閉瀏覽器和關(guān)閉標(biāo)簽頁無法監(jiān)聽。
以上所述是本文的全部內(nèi)容,寫的不好還請各位大俠多多提出寶貴意見。
相關(guān)文章
JS實(shí)現(xiàn)的RGB網(wǎng)頁顏色在線取色器完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)的RGB網(wǎng)頁顏色在線取色器,結(jié)合完整實(shí)例形式分析了基于JS運(yùn)算及鼠標(biāo)事件響應(yīng)來操作頁面元素實(shí)現(xiàn)取色器功能的方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12
uni-app微信小程序登錄并使用vuex存儲(chǔ)登錄狀態(tài)的思路詳解
這篇文章主要介紹了uni-app微信小程序登錄并使用vuex存儲(chǔ)登錄態(tài)的思路,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11
JavaScript循環(huán)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了JavaScript循環(huán)的相關(guān)資料,JavaScript的兩種循環(huán)方式,一種是for循環(huán),另while一種是循環(huán)具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
全面解析Bootstrap中tab(選項(xiàng)卡)的使用方法
這篇文章主要為大家全面解析Bootstrap中tab(選項(xiàng)卡)的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06
一文教會(huì)你微信小程序如何實(shí)現(xiàn)登錄
微信小程序頁面畫好后,需要開始做一系列和用戶的交互功能了,首先就是登錄,這篇文章主要給大家介紹了關(guān)于微信小程序如何實(shí)現(xiàn)登錄的相關(guān)資料,需要的朋友可以參考下2022-07-07
iframe的onload在Chrome/Opera中執(zhí)行兩次Bug的解決方法
創(chuàng)建iframe對象,添加load事件, 再將iframe添加到body中。Chrome/Opera中會(huì)造成load事件的handler執(zhí)行兩次。2011-03-03
使用bootstrap插件實(shí)現(xiàn)模態(tài)框效果
今天我們選擇使用著名的 bootstrap 庫的模態(tài)框插件 modal.js 來實(shí)現(xiàn)模態(tài)框效果,同時(shí)也使大家進(jìn)一步熟悉 bootstrap 的插件使用,需要的朋友可以參考下2017-05-05

