判斷用戶的在線狀態(tài) onbeforeunload事件
更新時間:2011年03月05日 11:51:50 作者:
window.event.clientX和window.event.clientY 將捕捉當前事件發(fā)生時鼠標相對與窗口的桌面坐標,通常情況下IE的關閉按鈕都會在頁面的右上部分,所以點關閉的時候鼠標的坐標的Y坐標一定是小于0的
獲得用戶登陸狀態(tài)不用說了,判斷離開的話就有一點問題了,如果說用戶都是按照設計者的規(guī)定觸發(fā)退出事件離開的話那就沒什么難度了,但是用戶的離開方式多種多樣,怎么在用戶非法離開的時候即時的判斷離開呢?最常見的非法離開就是關閉瀏覽器了。
<BODY onbeforeunload="body_onUnload()">
<script>
window.onbeforeunload = function() {
if (window.event.clientX>document.body.clientWidth&&event.clientY<0||event.altKey)
{
alert("瀏覽器關閉");
}
else
{
alert("刷新或者跳轉到其他頁");
}
}
</script>
</BODY>
以上是一個片段,BODY 的 UNLOAD和onbeforeunload事件會在瀏覽器清除所加載的信息時被觸發(fā),也就是說頁面在回送、重定向或被關閉的時候就會觸發(fā) ,通過這個事件加上JAVASCRIPT處理就可以實現(xiàn)非法關閉瀏覽器也即時統(tǒng)計在線人數(shù)了。
但是有個問題,怎么判斷用戶是關閉還是刷新、回送、重定向呢?
window.event.clientX和window.event.clientY 將捕捉當前事件發(fā)生時鼠標相對與窗口的桌面坐標,通常情況下IE的關閉按鈕都會在頁面的右上部分,所以點關閉的時候鼠標的坐標的Y坐標一定是小于0的,另外,鼠標坐標的X方向上坐標數(shù)值會大于窗體寬度,所以,從這兩個條件就可以判斷鼠標是不是在點關閉按鈕引發(fā)的onbeforeload事件。
還有一種關閉方法是ALT+F4 ,通過event.altKey就可以判斷,事件發(fā)生的時候ALT鍵是不是被按下了,這樣也就判斷出了是不是時候ALT+F4來關閉窗口。
不過也出現(xiàn)一個問題,當使用一些特殊的左面主題的時候 關閉按鈕可觸發(fā)的坐標數(shù)值不一定小于窗體寬度,所以,上面例子中的window.event.clientX>document.body.clientWidth這個條件可以不要.
復制代碼 代碼如下:
<BODY onbeforeunload="body_onUnload()">
<script>
window.onbeforeunload = function() {
if (window.event.clientX>document.body.clientWidth&&event.clientY<0||event.altKey)
{
alert("瀏覽器關閉");
}
else
{
alert("刷新或者跳轉到其他頁");
}
}
</script>
</BODY>
以上是一個片段,BODY 的 UNLOAD和onbeforeunload事件會在瀏覽器清除所加載的信息時被觸發(fā),也就是說頁面在回送、重定向或被關閉的時候就會觸發(fā) ,通過這個事件加上JAVASCRIPT處理就可以實現(xiàn)非法關閉瀏覽器也即時統(tǒng)計在線人數(shù)了。
但是有個問題,怎么判斷用戶是關閉還是刷新、回送、重定向呢?
window.event.clientX和window.event.clientY 將捕捉當前事件發(fā)生時鼠標相對與窗口的桌面坐標,通常情況下IE的關閉按鈕都會在頁面的右上部分,所以點關閉的時候鼠標的坐標的Y坐標一定是小于0的,另外,鼠標坐標的X方向上坐標數(shù)值會大于窗體寬度,所以,從這兩個條件就可以判斷鼠標是不是在點關閉按鈕引發(fā)的onbeforeload事件。
還有一種關閉方法是ALT+F4 ,通過event.altKey就可以判斷,事件發(fā)生的時候ALT鍵是不是被按下了,這樣也就判斷出了是不是時候ALT+F4來關閉窗口。
不過也出現(xiàn)一個問題,當使用一些特殊的左面主題的時候 關閉按鈕可觸發(fā)的坐標數(shù)值不一定小于窗體寬度,所以,上面例子中的window.event.clientX>document.body.clientWidth這個條件可以不要.
相關文章
Makefile/cmake/node-gyp中區(qū)分判斷不同平臺的方法
今天小編就為大家分享一篇關于Makefile/cmake/node-gyp中區(qū)分判斷不同平臺的方法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12javascript獲取wx.config內部字段解決微信分享
這篇文章主要介紹了javascript獲取wx.config內部字段解決微信分享,需要的朋友可以參考下2016-03-03for循環(huán) + setTimeout 結合一些示例(前端面試題)
最近在學習node.js開發(fā)資料,正好碰到了for循環(huán)+settimeout的經(jīng)典例子,下面小編給大家分享for循環(huán) + setTimeout 結合一些示例代碼,需要的朋友參考下吧2017-08-08