javascript监听页面刷新和页面关闭事件方法详解

在我们的日常生活中,时常遇到这么一种情况,当我们在点击一个链接关闭页面、表单提交时等情况,会提示我们是否确认该操作等信息。

这里就给大家讲讲javascript的onbeforeunload()和onunload()两个事件。

相同点:

两者都是在对页面关闭或刷新事件作个操作。

不同点:

  1. unbeforeunload()事件执行的顺序在onunload()事件之前发生。(因为,unbeforeunload()是在页面刷新之前触发的事件,而onubload()是在页面关闭之后才会触发的)。
  2. unbeforeunload()事件可以禁止onunload()事件的触发。
  3. onunload()事件是无法阻止页面关闭的。
  4. 浏览器的兼容

onunload:

IE6,IE7,IE8 中 刷新页面关闭浏览器之后、页面跳转之后都会执行;

IE9 刷新页面 会执行,页面跳转关闭浏览器不能执行;

firefox(包括firefox3.6) 关闭标签之后、页面跳转之后、刷新页面之后能执行,但关闭浏览器不能执行;

Safari 刷新页面页面跳转之后会执行,但关闭浏览器不能执行;

Opera、Chrome 任何情况都不执行。

onbeforeunload:

IE、Chrome、Safari 完美支持

Firefox 不支持文字提醒信息

Opera 不支持

IE6,IE7会出现bug  

示例代码:

onbeforeunload():

方式一:html元素中添加

rush:xhtml;"> <Meta charset="utf-8"> 该实例演示了如何向 body 元素添加 "onbeforeunload" 事件。

关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。

方式二:javascript中添加

方式三:添加addEventListener()事件(不过此方法IE8以下不支持)

rush:xhtml;"> <Meta charset="utf-8">

该实例演示了如何使用 addEventListener() 方法向 body 元素添加 "onbeforeunload" 事件。

关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。

跳转地址

onunload():

方式一:html元素中添加

rush:xhtml;">

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程之家!

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面