在我们的日常生活中,时常遇到这么一种情况,当我们在点击一个链接、关闭页面、表单提交时等情况,会提示我们是否确认该操作等信息。
这里就给大家讲讲javascript的onbeforeunload()和onunload()两个事件。
相同点:
不同点:
- unbeforeunload()事件执行的顺序在onunload()事件之前发生。(因为,unbeforeunload()是在页面刷新之前触发的事件,而onubload()是在页面关闭之后才会触发的)。
- unbeforeunload()事件可以禁止onunload()事件的触发。
- onunload()事件是无法阻止页面关闭的。
- 浏览器的兼容
onunload:
IE6,IE7,IE8 中 刷新页面、关闭浏览器之后、页面跳转之后都会执行;
firefox(包括firefox3.6) 关闭标签之后、页面跳转之后、刷新页面之后能执行,但关闭浏览器不能执行;
Safari 刷新页面、页面跳转之后会执行,但关闭浏览器不能执行;
Opera、Chrome 任何情况都不执行。
@H_404_39@
onbeforeunload:
IE、Chrome、Safari 完美支持
Opera 不支持
IE6,IE7会出现bug
示例代码:
onbeforeunload():
方式一:html元素中添加
<Meta charset="utf-8">
该实例演示了如何向 body 元素添加 "onbeforeunload" 事件。
关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。
方式二:javascript中添加
菜鸟教程(runoob.com)
该实例演示了如何使用 HTML DOM 向 body 元素添加 "onbeforeunload" 事件。
关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。
方式三:添加addEventListener()事件(不过此方法IE8以下不支持)
<Meta charset="utf-8">
该实例演示了如何使用 addEventListener() 方法向 body 元素添加 "onbeforeunload" 事件。
关闭当前窗口,按下 F5 或点击以下链接触发 onbeforeunload 事件。
跳转地址