如何制作';您确定要离开此页面吗';浏览器中的警告消息
本文关键字:浏览器 警告 消息 离开 何制作 | 更新日期: 2023-09-27 18:25:20
我有一个网页,其中包含一个文本框和一个提交按钮。当用户编辑文本框中的文本并单击另一个链接(而不是提交按钮)时,我如何显示"您确定要离开此页面吗"弹出消息?
我在网上对此进行了研究,发现了一些javascript示例。这是你能做到的唯一方法吗?如果没有,最好的方法是什么?
这是实现相同的多种方法之一
function goodbye(e) {
if(!e) e = window.event;
//e.cancelBubble is supported by IE - this will kill the bubbling process.
e.cancelBubble = true;
e.returnValue = 'You sure you want to leave?'; //This is displayed on the dialog
//e.stopPropagation works in Firefox.
if (e.stopPropagation) {
e.stopPropagation();
e.preventDefault();
}
}
window.onbeforeunload=goodbye;
从这里获得打开js
只有unload()事件才能在JS上工作。您无法在服务器上管理它。
查看SO上另一个问题的答案,它与您的问题非常相似
如何显示";是否确实要离开此页面"何时提交更改?
简单解决方案
window.onbeforeunload = confirmExit;
function confirmExit() {
return "Are you sure you want to leave this page?";
}
4guysFromRolla.com-在离开页面时提示用户保存
您不能使用onbeforenload窗口方法,因为它是由多种方式触发的,如来回浏览器导航链接、刷新页面、关闭页面、单击链接。
我觉得你必须绑定你想要显示导航离开消息的链接标签,然后使用状态消息显示的功能
window.addEvent('domready',function(){
$$('a').addEvent('click', function(e) {
//leaving(); function u wrote for displaying message
});
});
function leaving(e) {
if(!e)
e = window.event;
// return code for the displaying message
}
如果您想保证它在几乎所有浏览器上都能工作,请使用JQuery库。下面介绍卸载事件。
http://www.w3schools.com/jquery/event_unload.asp
这完全是为了你的目的。
为了详细说明一下,您必须下载jquery-js库并在项目/页面中引用它,但您可能最终还是想这样做。
如果要从服务器端控制此操作,可以在OnPreRender中动态发出jquery调用。
查看Jquery的.bforeunload属性。这里有一个例子:
$(window).bind('beforeunload', function(){ return 'Click OK to exit'; });
请注意,在卸载之前,由于明显的原因,无法阻止页面卸载或重定向到另一个页面;它太容易被滥用了。此外,如果您只想在卸载前运行一个函数,请尝试以下操作:
$(window).unload(function(){ alert('Bye.'); });
最后,不要忘记在你的head标签中引用jQuery,方法是:
<script src="http://code.jquery.com/jquery-latest.min.js" type="text/javascript"></script>
上面的内容可以让你从互联网上获得最新版本,并省去下载的麻烦,当然你也可以选择这样做,但我只是想让你的东西尽快发挥作用。哦,我还为你找到了一个例子。单击此处查看在函数关闭之前调用该函数的页面。希望这对巴德有所帮助。
我能够使用Andrei G的答案。为了让它在Chrome中运行,我会在他的再见功能的末尾添加这个:
return";