【Web】简谈如何监听浏览器的关闭
> 参考的优秀文章
想起以前做的一个小系统,一个企业内部小型的测试系统,让考生在给定时间内完成考试,如果考生中退出,那么下次进来可以利用剩余的考试时间继续完成考试。
这里遇到一个问题,如何监听考生的退出。从Web技术上来讲,就是如何监听用户在正常情况下,或异常情况下退出浏览器。
> 利用beforeunload事件
如此文章beforeunload实现关闭离开的提示所述,可使用此方法实现。
但有两个严重缺陷:
- 不能保证100%监听成功。比如电脑突然断电,浏览器根本来不及调用回调的方法就退出了。
- 部分浏览不支持。
> 轮询
在页面每间隔一段时间轮询后台,一旦页面停止了轮询,即表示已经退出了浏览器。但这只适用于小型的内部系统,因为大型系统流量太大,服务器负载太重。
【Web】简谈如何监听浏览器的关闭的更多相关文章
- 雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
		Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播.在视频业务大数据平台中,播放数据的统计分析非常重要,所以We ... 
- JS实时监听浏览器宽度的变化
		boot:function(){ //加载页面时执行一次 changeMargin(); //监听浏览器宽度的改变 window.onresize = function(){ changeMargin ... 
- js监听浏览器tab窗口切换
		js监听浏览器tab窗口切换 ——IT唐伯虎 摘要:js监听浏览器tab窗口切换. if (document.hidden !== undefined) { document.addEventLis ... 
- vue监听浏览器窗口大小变化
		首先,页面初始化mounted的时候,通过 document.body.clientWidth 和 document.body.clientHeight 来获取到浏览器的宽和高,然后通过 window ... 
- vue JS实现监听浏览器返回按键事件
		// 这个是监听浏览器回退键的returnButton () { let vm = this; $(document).ready(function () { if (window.history & ... 
- JS监听浏览器标签页的显示与隐藏
		/** * 监听浏览器标签页的显示与隐藏 */ class ListenerPageVisibility { constructor () { // 设置隐藏属性和改变可见属性的事件的名称 this. ... 
- 【hugo】- hugo 监听浏览器切换title
		hugo 博客 监听浏览器title 动态改变浏览器title标题 找到head.html themes/maupassant/layouts/partials/head.html 添加监听js 可以 ... 
- 监听浏览器tab切换
		监听浏览器切屏 为了完成验证用户在切换浏览器tab时进行登录再次认证需求需要监听浏览器切换窗口 if (document.hidden !== undefined) { document.addEve ... 
- JS 监听浏览器各个标签间的切换
		以前看到过一些网页,在标签切换到其它地址时,网页上的标题上会发生变化,一直不知道这个是怎么做的,最近查了一些资料才发现有一个 visibilitychange 事件就可以搞定,这里将介绍一下页面可见性 ... 
随机推荐
- hdu5381 The sum of gcd
			莫队算法,预处理出每个数字往后的gcd情况,每个数字的gcd只可能是他的因子,因此后面最多只可能有logn种,可以先预处理出,然后套莫队算法,复杂度O(n*sqrt(n)*log(n)). 代码 #i ... 
- CentOs5.2中PHP的升级
			最近一个项目中需要使用到PHP5.2的版本,而服务器上使用了官方的yum源进行安装,默认的版本是5.1.6,需要升级.但是因为不是一个非常 正式的服务器环境,所以想通过简单的yum update一下了 ... 
- java socket 发送文件
			客户端: package tt; import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStrea ... 
- IUS通过PLI产生fsdb波形
			IUS通过PLI接口来调用系统函数,产生fsdb波形,再由verdi来debug. 要调用fsdbDumpfile和fsdbDumpvars,需要在testcase的shell(或.cshrc等)中设 ... 
- [MaxOSX] 路由操作
			查看当前路由情况 netstat -nr 添加路由 sudo route -n add x.x.x.x/24 x.x.x.x 可以简单这样子理解: 第1个参数 x.x.x.x/24是远程地址 第2个参 ... 
- scala特质
			package com.ming.test /** * scala 特质,类似与java接口,但是比java接口强大,可以有实现方法,定义字段之类的 */ /** * 定义一个日志的特质 */ tra ... 
- IEnumerator:概念详解
			IEnumerable接口是非常的简单,只包含一个抽象的方法GetEnumerator(),它返回一个可用于循环访问集合的IEnumerator对象.IEnumerator对象有什么呢?它是一个真正的 ... 
- javaWeb 使用 jsp 和 javaBean 实现计算器功能
			<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ... 
- JVM学习笔记(四)------内存调优【转】
			转自:http://blog.csdn.net/cutesource/article/details/5907418 版权声明:本文为博主原创文章,未经博主允许不得转载. 首先需要注意的是在对JVM内 ... 
- Java使用基本字节流OutputStream的四种方式对于数据复制(文本,音视频,图像等数据)
			//package 字符缓冲流bufferreaderDemo; import java.io.BufferedOutputStream; import java.io.FileInputStream ... 
