欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

Firefox中beforeunload事件的实现缺陷浅析_javascript技巧

程序员文章站 2022-05-27 10:34:10
...
beforeunload 指在页面卸载前提供的最后一次JS执行的机会。如下
复制代码 代码如下:

window.onbeforeunload = function() {
return '您正在编辑的博客尚未保存,确定要离开此页吗?';
};

可以使用返回值文字来提示用户。但只有Firefox中却不显示该文字。
当刷新页面时,各浏览器表现如下

IE:

Firefox中beforeunload事件的实现缺陷浅析_javascript技巧

Chrome:

Firefox中beforeunload事件的实现缺陷浅析_javascript技巧

Firefox12:

Firefox中beforeunload事件的实现缺陷浅析_javascript技巧

Mozilla官方说Firefox4之前的版本可以通过事件对象的returnValue修改该值,如下
复制代码 代码如下:

window.onbeforeunload = function(e) {
e = e || window.event;

// For IE and Firefox prior to version 4
if (e) {
e.returnValue = 'Any string';
}
return '您正在编辑的博客尚未保存,确定要离开此页吗?';
};

相关:
https://developer.mozilla.org/en/DOM/window.onbeforeunload
https://bugzilla.mozilla.org/show_bug.cgi?id=588292
相关标签: beforeunload 缺陷