监听浏览器关闭按钮点击事件 -- 使用JS

 
Onunload与Onbeforeunload
Onunload,onbeforeunload都是在刷新或关闭时调用,可以在   
  •    
  •  
    这段代码在FF和IE上都能正确执行.再点击关闭按钮时首先触发obbeforeunload事件,点击否定时不执行onload事件.
    通常应用在 注销session等等登陆信息 等方面....
     
    这里一并推荐一个教程 ActionScript3 里面写道:
    运用onunload事件判断浏览器是刷新还是关闭窗口
    function CloseOpen(event) {
    if(event.clientX<=0 && event.clientY<0) {
    alert("关闭");
    }
    else
    {
    alert("刷新或离开");
    }
    }
     
    Java代码
    1. window.onbeforeunload = function() //author: meizz    
    2.        {    
    3.               var n = window.event.screenX - window.screenLeft;    
    4.               var b = n > document.documentElement.scrollWidth-20;    
    5.               if(b && window.event.clientY < 0 || window.event.altKey)    
    6.               {    
    7.                      alert("是关闭而非刷新");    
    8.                      window.event.returnValue = ""//这里可以放置你想做的操作代码    
    9.               }    
    10.        }  

    ------------------------------------------------------------------------------------------

    另一篇的转载:

    最近写东西的时候发现需要对浏览器的关闭进行监听,当用户关闭的时候需要调用session.invalid();清空session信息,但是仔细一查手册发现无论是body还是window都没有onclose事件,之后onload,onunload,beforeunload三个事件

    然而三个时间无论是哪个都无法单独解决单独监听浏览器关闭的事件,因为在浏览器正常运行时先加载的是beforeunload->onunload->onload 但是麻烦的是如果刷新页面时是执行beforeunload->onunload,如果关闭浏览器的话是执行onunload(实际上关闭浏览器beforeunload也执行的).如果单单监听onunload的话是无法区别用户是刷新还是关闭窗口的.所以就要用beforeunload来监测了

    window.οnbefοreunlοad=onclose;

    function onclose()
    {
        if(event.clientX>document.body.clientWidth&&event.clientY<0||event.altKey)
        {
               removeSession();//这里添加具体的处理方案
        }
    }

    经过测试,IE7浏览器可以监测监听到 alt+f4 或者单击右上角小叉子退出,但是对于多选项卡浏览的用户貌似无法监听到这点比较可惜~

     

     

    你可能感兴趣的:(javaScript)