js如何实现在监测页面关闭和刷新事件
有一个需求,当用户在页面中进行刷新和关闭页面的时候显示一个弹框提示用户功能。
于是自己就想到onbeforeunload、onunload、onload这几个事件,但是在使用的过程中有种心累的感觉。。。
onbeforeunload:在页面刷新和关闭的时候触发事件,表示正要去服务器读 取新的页面时调用,此时还没开始读取,
onunload:则已经从服务器上读到了需要加载的新的页面,在即将替换掉当前页面时调用。
onload就不用说了
onbrforeunload和onunload都会在刷新和关闭页面是触发,但是onbeforeunload在onunload之前执行,并且它还可以阻止onunload的执行。那么在页面刷新时执行顺序就是onbeforeunload、onunload、onload
但是在使用的过程中,自己深深的踩了一个坑
首先是是兼容性的问题:
正如你看到的菜鸟教程和w3c上的介绍是多么的赏心悦目
但是现实总是残酷的,onbeforeunload事件在ie和谷歌中都没有问题,但是在火狐中却没有任何反应,代码如下:
Document//这个在火狐下不起作用
window.οnbefοreunlοad=function(e){
return "我在这写点东西";
}
window.οnunlοad=function(){
alert("离开")
}
window.οnlοad=function(){
alert("加载完成");
}
onbeforeunload中的return是自定义提示信息,并且如果没有return在谷歌中是不会有反应,ie则不会出现这个情况。
onunload事件也只有在ie中才起作用,在其他浏览器中也没有反应。
不知道哪位大神可以解答一下,怎么解决这些问题(百度找了好多,都是一些没有用的方法...)
相关阅读:
请问原子行内级盒怎么参加行内格式化上下文
异步执行函数 实现函数asyncEach,依次执行函数func1,func2,func3的异步控制
apk反编译之后找不到对应的类有哪些原因?
Vue如何做到前进刷新数据,后退不刷新数据呢?
php如何过滤RLO字符,防止文字翻转
jquary 每秒selector用法
mac桌面如何删除图中的东西
JQ中的show跟hide方法为什么鼠标已经移开了还不停的在哪动呢
js怎么获取滚动条的总宽度?
vue-router 怎么改变网站的title。
centos 7 下用 yum install 命令安装python依赖包,一直提示“没有可用软件包”?
如何用 npm 安装 zepto 的 deferred 模块
python,url异常捕获
vue中使用websocket,无法调用methods
python与PHP互动
你们表单验证用什么插件
PHP统计问题
想要知道选中的是那个选项下边的哪个checkbox这个咋做呀
如何实现两栏布局
开发的electron软件 运行在linux平台的解决方案