php 页面关闭触发,javascript,html5_js如何实现在监测页面关闭和刷新事件,javascript,html5,html,css - phpStudy...

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平台的解决方案

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值