欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript判斷網(wǎng)頁是關(guān)閉還是刷新

 更新時間:2015年09月12日 10:33:31   作者:kbeer  
本篇文章給大家介紹js判斷網(wǎng)頁是關(guān)閉還是刷新,實(shí)現(xiàn)原理就是通過離開頁面行為時間onunload觸發(fā)時間去檢測此時的瀏覽器的窗口大小,根據(jù)大小由此判斷用戶是刷新,跳轉(zhuǎn)或是關(guān)閉行為程序,需要的朋友可以參考下本文

原理就是通過離開頁面行為時間onunload觸發(fā)時間去檢測此時的瀏覽器的窗口大小,根據(jù)大小由此判斷用戶是刷新,跳轉(zhuǎn)或是關(guān)閉行為程序

 代碼如下 

window.onunload = function(){    
    var a_n = window.event.screenX - window.screenLeft;    
    var a_b = a_n > document.documentElement.scrollWidth-20;    
    if(a_b && window.event.clientY< 0 || window.event.altKey){    
         alert('關(guān)閉頁面行為'); 
    }else{ 
         alert('跳轉(zhuǎn)或者刷新頁面行為');   
      } 
}

用瀏覽器右上角的關(guān)閉按鈕時好用,但在選項(xiàng)卡上關(guān)閉和在任務(wù)欄上關(guān)閉,這個方法就不作用了

js標(biāo)簽只有onloadonunloadonbeforeunload事件,而沒有onclose事件。

不管頁面是關(guān)閉還是刷新都會執(zhí)行onunload事件。

如何捕捉到頁面關(guān)閉呢?
頁面加載時只執(zhí)行onload
頁面關(guān)閉時只執(zhí)行onunload
頁面刷新時先執(zhí)行onbeforeunload,然后onunload,最后onload。

這樣我們可以在onbeforeunload中加一個標(biāo)記,在onunload中判斷該標(biāo)記,即可達(dá)到判斷頁面是否真的關(guān)閉了
更完整的兼容ff

 代碼如下 

<mce:script type="text/javascript"><!--
    function close(evt) //author: sunlei
    {  
      var isIE=document.all?true:false;
      evt = evt ? evt :(window.event ? window.event : null);
      if(isIE){//IE瀏覽器
        var n = evt.screenX - window.screenLeft;
        var b = n > document.documentElement.scrollWidth-20;
        if(b && evt.clientY<0 || evt.altKey){
          //alert("是關(guān)閉而非刷新");
          window.location.href="../include/logout.php";
        }
        else{
          //alert("是刷新而非關(guān)閉");
          return false;
        }
      }
      else{//火狐瀏覽器
        if(document.documentElement.scrollWidth!=0)
        {
          //alert("是刷新而非關(guān)閉");
          //window.location.href="report_list.php?ss=1";
          return false;
          
        }
        else{
          alert("是關(guān)閉而非刷新");
          //window.location.href="repost_list.php?ss=0";
          //alert("bbbbbbb");
        }
      }
    }
// --></mce:script>
<BODY onunload="close(event);"> 

上面的方法沒辦法判斷多選項(xiàng)卡的瀏覽器,如360,ie8這種,下面再看

 代碼如下 

function CloseOpen(event) { 
     if(event.clientX<=0 || event.clientY<0) { 
       //獲取當(dāng)前時間
      var date=new Date();
      //將date設(shè)置為過去的時間
      alert("關(guān)閉網(wǎng)頁");
      date.setTime(date.getTime()-10000);
      //將userId這個cookie刪除
      document.cookie="zhuangtao;expire="+date.toUTCString();
      document.cookie="quanxianzifucuan;expire="+date.toUTCString();
      document.cookie="quanxian;expire="+date.toUTCString();
     s0 += "關(guān)閉窗口!"; sw = 1;
      onbeforeunload();
      // window.event.returnValue = '關(guān)閉瀏覽器將退出系統(tǒng).';
     } 
     else 
     { 
        alert("刷新或離開"); 
     } 
 } 
       
        var currentKeyCode = -1;

  function document.onkeydown() { // 本窗口的所有下屬頁面都必須含有本函數(shù)

    top.currentKeyCode = event.keyCode;
  }

  function onbeforeunload(){
  
   var sw = 0, s0 = "";
    if (currentKeyCode == 116) 
    {
      s0 += "刷新窗口!(F5)";
    }
    else 
    {
      if ((event.altKey)&&(currentKeyCode == 115)) 
      {
         s0 += "關(guān)閉窗口!(alt+F4)"; sw = 1;
          //獲取當(dāng)前時間
          var date=new Date();
          //將date設(shè)置為過去的時間
         alert("關(guān)閉窗口");
          date.setTime(date.getTime()-10000);
          //將userId這個cookie刪除
          document.cookie="zhuangtao;expire="+date.toUTCString();
          document.cookie="quanxianzifucuan;expire="+date.toUTCString();
          document.cookie="quanxian;expire="+date.toUTCString();
      }
      else 
      {
        if ((event.clientX > 0)&&(event.clientX < document.body.clientWidth)) 
        {
         s0 += "刷新窗口!";
        }
        else 
        {
        //獲取當(dāng)前時間
          var date=new Date();
          //將date設(shè)置為過去的時間
          alert("關(guān)閉網(wǎng)頁");
          date.setTime(date.getTime()-10000);
          //將userId這個cookie刪除
          document.cookie="zhuangtao;expire="+date.toUTCString();
          document.cookie="quanxianzifucuan;expire="+date.toUTCString();
          document.cookie="quanxian;expire="+date.toUTCString();
         s0 += "關(guān)閉窗口!"; sw = 1;
        }
      }
    }
    if (sw == 1) 
    {
     event.returnValue = "";
    }
    else 
    {
     currentKeyCode = -1;
    }
  
  }

<body onunload="CloseOpen(event)" ></body></html>

上面只有不能使用在任務(wù)欄關(guān)閉了,基本可以滿足我們的要求了。

以上內(nèi)容就是本文給大家介紹的javascript判斷網(wǎng)頁是關(guān)閉還是刷新,希望大家喜歡。

相關(guān)文章

  • 用IE重起計(jì)算機(jī)或者關(guān)機(jī)的示例代碼

    用IE重起計(jì)算機(jī)或者關(guān)機(jī)的示例代碼

    本篇文章主要是對用IE重起計(jì)算機(jī)或者關(guān)機(jī)的實(shí)現(xiàn)代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • javascript進(jìn)行數(shù)組追加方法小結(jié)

    javascript進(jìn)行數(shù)組追加方法小結(jié)

    javascript中給數(shù)組加元素是一個非常簡單的問題,javascript本身就提供了大量這類函數(shù),我們可以使用js自帶函數(shù)快速給數(shù)組增加元素了,本文就javascript進(jìn)行數(shù)組追加的方法做出如下小結(jié)。
    2014-06-06
  • 微信小程序之事件交互操作實(shí)例分析

    微信小程序之事件交互操作實(shí)例分析

    這篇文章主要介紹了微信小程序之事件交互操作,結(jié)合實(shí)例形式分析了微信小程序事件響應(yīng)、交互及界面布局等相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2018-12-12
  • 控制文字內(nèi)容的顯示與隱藏示例

    控制文字內(nèi)容的顯示與隱藏示例

    控制某id或class的地div顯示與隱藏是比較容易實(shí)現(xiàn)的,但若控制文字內(nèi)容的顯示與隱藏該如何做到呢?下面有個示例,大家可以參考下
    2014-06-06
  • js仿微博動態(tài)欄功能

    js仿微博動態(tài)欄功能

    本文主要介紹了js仿微博動態(tài)欄功能的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • 最新評論