JS判断浏览器是否是关闭
来源:互联网 发布:安卓微信聊天恢复软件 编辑:程序博客网 时间:2024/05/16 10:19
js标签只有onload"onunload"onbeforeunload事件,而没有onclose事件。不管页面是关闭还是刷新都会执行onunload事件。如何捕捉到页面关闭呢?
页面加载时只执行onload
页面关闭时只执行onunload
页面刷新时先执行onbeforeunload,然后onunload,最后onload。这样我们可以在onbeforeunload中加一个标记,在onunload中判断该标记,即可达到判断页面是否真的关闭了。
触发于:
- 关闭浏览器窗口
- 通过地址栏或收藏夹前往其他页面的时候
- 点击返回,前进,刷新,主页其中一个的时候
- 点击 一个前往其他页面的url连接的时候
- 调用以下任意一个事件的时候:click,document write,document open,document close,windowclose ,window navigate ,window NavigateAndFind,locationreplace,location reload,form submit.
- 当用window open打开一个页面,并把本页的window的名字传给要打开的页面的时候。
- 重新赋予location.href的值的时候。
- 通过input type=”submit”按钮提交一个具有指定action的表单的时候。
可以用在以下元素:
BODY, FRAMESET, window
平台支持:
IE4+/Win, Mozilla 1.7a+, Netscape 7.2+, Firefox0.9+
// 方法1:
window.onbeforeunload = function(event) {
var n = event.screenX - window.screenLeft;
var b = n > document.documentElement.scrollWidth-20;
if(b && event.clientY < 0 || event.altKey) {
alert("是关闭而非刷新");
window.open(this.location);
//return false;
//window.event.returnValue = ""; }
} else{
alert("是刷新而非关闭");
}
}
// 方法二:
/*
function promptOnClose(e){
//e = e ? e : windowevent;
var promptString = '你是否要离开此页面,离开该页面的信息将不被保存!';
//e.returnValue = promptString;
return promptString;
}
if (window != top){
top.location.href = "www.baidu.com";
}else{
if (window.Event) {
window.onbeforeunload = function(event) {
var isClose = promptOnClose(event);
return isClose;
alert('bbb');
}
} else {
window.onbeforeunload = function() {
return promptOnClose(event);
}
}
}
*/
/*window.onunload = function(){
alert('关闭窗体!');
}*/
// 在FF中 如果 点击浏览器的 关闭按钮(不是选项卡的关闭按钮) 无法监测到
- JS判断浏览器是否是关闭
- JS判断浏览器是否是关闭
- js判断浏览器是否关闭
- js判断多标签浏览器是否关闭
- js 判断浏览器是否是IE
- js 判断是否是IE浏览器
- js判断浏览器是否是ie
- Js判断浏览器是否是移动设备
- JS判断是否是IE浏览器
- 使用js判断是否是IE浏览器
- Js判断是否是IE浏览器
- js判断浏览器关闭
- js判断浏览器关闭
- js判断浏览器关闭
- js 判断浏览器插件,判断是否是windows机器
- js中 判断浏览器是否是 ie的函数
- JS判断是否是IE浏览器仅仅需要7bytes!
- js判断手机浏览器版本和是否是ios9版本
- dbms_lob包学习笔记之三:instr和substr存储过程
- js页面定位,相关几个属性
- 产品设计之开餐馆
- asp中的getrows和getstring用法
- C#源程序 打包成安装文件 的步骤
- JS判断浏览器是否是关闭
- 字节?
- Oracle大对象处理
- CSS Bug Table
- HDU2441ACM(Array Complicated Manipulation)题解数论
- ORACLE中LOB字段的使用和维护
- 常用 seo
- new
- Linux中.a,.la,.o,.so文件的意义和编程实现