beforeunload event 当浏览器窗口关闭或者刷新时触发

2020-11-26 11:02:24

我再删除localStorage的时候,显示删除成功了,刷新后发信又出现了,并且还是原来的,我就想肯定是关闭的时候,浏览器又触发了存储变量到localStorage


找了半天,发现 

window.addEventListener('beforeunload', ()

就是检测浏览器窗口关闭和刷新的,还以为是检测上传图片呢。哎

下面介绍下beforeunload


参考地址 Window: beforeunload event


当浏览器窗口关闭或者刷新时,会触发beforeunload事件。当前页面不会直接关闭,可以点击确定按钮关闭或刷新,也可以取消关闭或刷新。

BubblesNo
CancelableYes
InterfaceEvent
Event handler propertyonbeforeunload

事件使网页能够触发一个确认对话框,询问用户是否真的要离开该页面。如果用户确认,浏览器将导航到新页面,否则导航将会取消。

根据规范,要显示确认对话框,事件处理程序需要在事件上调用preventDefault()

但是请注意,并非所有浏览器都支持此方法,而有些浏览器需要事件处理程序实现两个遗留方法中的一个作为代替:

  • 将字符串分配给事件的returnValue属性

  • 从事件处理程序返回一个字符串。

某些浏览器过去在确认对话框中显示返回的字符串,从而使事件处理程序能够向用户显示自定义消息。但是,此方法已被弃用,并且在大多数浏览器中不再支持。

为避免意外弹出窗口,除非页面已与之交互,否则浏览器可能不会显示在beforeunload事件中创建的提示,甚至根本不会显示它们。

将事件处理程序/监听器加到window或 documentbeforeunload事件后,将阻止浏览器使用内存中的页面导航缓存,例如Firefox的Back-Forward缓存WebKit的Page Cache

HTML规范指出在此事件中调用window.alert()window.confirm()以及window.prompt()方法,可能会失效。更多详细信息,请参见HTML规范

示例

HTML规范指出作者应该使用 Event.preventDefault() 而非 Event.returnValue,然而,不是所有浏览器都支持这么做。

window.addEventListener('beforeunload', (event) => {   // Cancel the event as stated by the standard.   event.preventDefault();   // Chrome requires returnValue to be set.   event.returnValue = ''; });

规范

规范状态注释
HTML Living Standard
beforeunload
Living Standard
HTML5
beforeunload
RecommendationInitial definition

浏览器兼容性

Update compatibility data on GitHub


DesktopMobile

ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewChrome for AndroidFirefox for AndroidOpera for AndroidSafari on iOSSamsung Internet
beforeunload eventFull support1Full support12Full support1Full support4Full support12Full support3Full support1Full support18Full support4Full support12Full support1Full support1.0
Custom text supportDeprecatedNon-standardNo support? — 51No supportNoNo support? — 44Full supportYesNo support? — 38No support? — 9No support? — 51No support? — 51No support? — 44No support? — 41No supportNoNo support? — 5.0
Activation using event.returnValue = "string";DeprecatedFull support30Full support12Full supportYesFull supportYes??Full supportYesFull supportYesFull supportYesFull supportYesNo supportNoFull supportYes
Activation using event.preventDefault()No supportNoNo support12 — 79Full supportYesFull support9No supportNoFull support11No supportNoNo supportNoFull supportYesNo supportNoNo supportNoNo supportNo
Activation using return "string";DeprecatedFull support1Full support12Full support1Full supportYesFull support12Full support3Full supportYesFull supportYesFull supportYesFull supportYesNo supportNoFull supportYes

What are we missing?

Legend

  • Full support 

  • Full support

  • No support 

  • No support

  • Compatibility unknown 

  • Compatibility unknown

  • Non-standard. Expect poor cross-browser support.

  • Non-standard. Expect poor cross-browser support.

  • Deprecated. Not for use in new websites.

  • Deprecated. Not for use in new websites.


  • 2017-04-02 00:52:26

    php-fpm占用系统资源分析

    由上图分析,可以看出共有602个进程,其中有601个进程休眠了。这好像有点不对劲,内核进程也就80个左右,加上memcached, nginx, mysqld,也不会超出90个。除了这些,剩下的只有php-fpm管理的php-cgi,难道是…?

  • 2017-04-02 00:56:36

    php-fpm占用系统资源分析

    由上图分析,可以看出共有602个进程,其中有601个进程休眠了。这好像有点不对劲,内核进程也就80个左右,加上memcached, nginx, mysqld,也不会超出90个。除了这些,剩下的只有php-fpm管理的php-cgi,难道是…?

  • 2017-04-03 14:23:17

    Android Studio --“Cannot resolve symbol” 解决办法

    Android Studio 无法识别同一个 package 里的其他类,将其显示为红色,但是 compile 没有问题。鼠标放上去后显示 “Cannot resolve symbol XXX”,重启 Android Studio,重新 sync gradle,Clean build 都没有用。

  • 2017-04-06 14:59:13

    PHP配置文件详解

    PHP是一个简单易学,功能强大的语言,尤其在Web开发,开发效率高,方便快捷。研究一下php.ini了解PHP相关配置会有好处的,对PHP有更加深入的了解。

  • 2017-04-06 15:00:46

    怎么实时查看mysql当前连接数

    今天有一台mysql服务器突然连接数暴增,并且等待进程全部被锁...因为问题解决不当,导致被骂...OTL 总结:以后要快速定位错误,布置解决方案

  • 2017-04-06 15:07:57

    PHP-FPM不完全指南

    fpm启动后会先读php.ini,然后再读相应的conf配置文件,conf配置可以覆盖php.ini的配置。 启动fpm之后,会创建一个master进程,监听9000端口(可配置),master进程又会根据fpm.conf/www.conf去创建若干子进程,子进程用于处理实际的业务。

  • 2017-04-06 15:11:03

    浅析php-fpm 和 mysql 之间的关系详解

    php-fpm 和 mysql 之间的关系估计不做底层开发应用的是不会去考虑分析它们了,如果是的话我们来看一篇关于php-fpm 和 mysql 之间的关系的教程。