DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 捕獲浏覽器關閉、刷新事件不同情況下的處理方法
捕獲浏覽器關閉、刷新事件不同情況下的處理方法
編輯:關於JavaScript     
在做一些關於會員在線的問題時,往往我們要根據覽器是否關閉來判斷用戶是否下線,然後再從session和application中將此用戶移除。

由於浏覽器是無狀態的,在這時候捕捉浏覽器關閉會出現兩種情況:
1.真正的關閉浏覽器 (a.點擊關閉按鈕 b.右擊任務欄關閉 c.按alt+F4關閉)
2.刷新浏覽器。

那如何判斷區分這兩種動作呢?

一. Javascript代碼處理方法:
復制代碼 代碼如下:
function window.onbeforeunload()
{
//用戶點擊浏覽器右上角關閉按鈕或是按alt+F4關閉
if(event.clientX>document.body.clientWidth&&event.clientY<0||event.altKey)
{
// alert("點關閉按鈕");
document.getElementById("hiddenForm:hiddenBtn").click();
// window.event.returnValue="確定要退出本頁嗎?";
}
//用戶點擊任務欄,右鍵關閉。s或是按alt+F4關閉
else if(event.clientY > document.body.clientHeight || event.altKey)
{
// alert("任務欄右擊關閉");
document.getElementById("hiddenForm:hiddenBtn").click();
// window.event.returnValue="確定要退出本頁嗎?";
}
//其他情況為刷新
else
{
// alert("刷新頁面");
}
}

其中 event.clientX 鼠標光標X坐標
document.body.clientWidth 窗體工作區寬度
event.clientY 鼠標光標Y坐標
event.altKey 是否按下alt鍵
二. 事件捕捉方法:
復制代碼 代碼如下:
<body scroll="no" onbeforeunload="return CloseEvent();" onunload="UnLoadEvent()" >
</body>
<script language="JavaScript" type="text/javascript">
var DispClose = true;
function CloseEvent()
{
if (DispClose)
{
return "是否離開當前頁面?";
}
}
function UnLoadEvent()
{
DispClose = false;
//在這裡處理關閉頁面前的動作
}
</script>

在頁面卸載之前引發onbeforeunload事件,如果用戶選擇“是”即確定卸載頁面將引發onunload事件,否則返回頁面不做任何操作。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved