[英]Js popup when leaving page but not when submitting form
当用户试图离开页面时,我在网站上使用以下代码在弹出窗口中显示警告消息:
<script type="text/javascript">
window.onbeforeunload = confirmExit;
function confirmExit()
{
return "Si vous quittez ou actualisez la page, vous perdrez votre tutoriel";
}
</script>
但是,这是在带有表单的页面上。 当用户提交表单时,会弹出没有意义的弹出窗口。 我如何修改此代码,以便仅当用户以各种可能的方式离开页面时(关闭选项卡,单击网站徽标,刷新页面),而在提交表单时才显示弹出窗口?
我建议捕获表单的confirmExit
事件,然后从onbeforeunload
事件绑定中删除confirmExit
函数,或者设置一个标志以指示可以提交页面。 例如:
<script type="text/javascript">
// Define flag to determine if the page can be left without confirmation
var safeToLeave = false;
// Handle user leaving the page
function handleExit () {
if (!safeToLeave) {
return 'Si vous quittez ou actualisez la page, vous perdrez votre tutoriel';
}
}
// Handle the user submitting the page form
function handleSubmission() {
safeToLeave = true;
}
// Bind to on evemts
window.onbeforeunload = handleExit;
document.getElementById('#my-form').onsubmit = handleSubmission;
</script>
我建议您一般考虑使用addEventListener
方法来绑定事件,但是考虑到您的示例,我尝试使答案保持一致。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.