js判断用户在线状态 onbeforeunload事件用法实例

发布时间:2020-06-28编辑:脚本学堂
本文介绍了js判断用户在线状态的方法,unload与onbeforeunload事件会在浏览器清除所加载的信息时被触发,页面在回送、重定向或被关闭时触发,通过此事件加上javascript处理即可实现非法关闭浏览器时统计在线人数。

js脚本中使用onbeforeunload事件判断用户在线状态的方法

window.event.clientX和window.event.clientY 将捕捉当前事件发生时鼠标相对与窗口的桌面坐标,通常情况下IE的关闭按钮都会在页面的右上部分,所以点关闭的时候鼠标的坐标的Y坐标一定是小于0的

获得用户登陆状态不用说了,判断离开的话会有些问题,如果说用户都是按照设计者的规定触发退出事件离开的话那就没什么难度了,但是用户的离开方式多种多样,怎么在用户非法离开的时候即时的判断离开呢?
最常见的非法离开就是关闭浏览器了。

例子:
 

复制代码 代码示例:
<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事件会在浏览器清除所加载的信息时被触发,也就是说页面在回送、重定向或被关闭的时候就会触发 ,通过这个事件加上javascript处理就可以实现非法关闭浏览器也即时统计在线人数了。 (www.jb200.com 脚本学堂)

怎么判断用户是关闭还是刷新、回送、重定向呢?

window.event.clientX和window.event.clientY 将捕捉当前事件发生时鼠标相对与窗口的桌面坐标,通常情况下IE的关闭按钮都会在页面的右上部分,所以点关闭的时候鼠标的坐标的Y坐标一定是小于0的。
另外,鼠标坐标的X方向上坐标数值会大于窗体宽度,所以,从这两个条件就可以判断鼠标是不是在点关闭按钮引发的onbeforeload事件。

另外一种关闭方法是ALT+F4 ,通过event.altKey就可以判断,事件发生时ALT键是不是被按下了,这样也就判断出了是不是时候ALT+F4来关闭窗口。

还是会有问题,当使用一些特殊的左面主题的时候 关闭按钮可触发的坐标数值不一定小于窗体宽度。
因此,以上例子中的window.event.clientX>document.body.clientWidth这个条件可以不要。