萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> 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事件,否則返回頁面不做任何操作。   
copyright © 萬盛學電腦網 all rights reserved