要做一个后台,编辑文章的功能,产品要求,当用户点开编辑窗口进行修改并没有保存时,点击编辑窗口以外的任何地方,阻止默认事件,弹窗令用户选择是否保存后再执行默认事件。
想来想去没有很好的解决办法,求一个思路.
问题主要在于不是关闭浏览器触发弹框,而是点击页面上的非编辑窗口部分时都要触发,而这些部分里有各种绑定事件、链接之类的。
回复内容:
要做一个后台,编辑文章的功能,产品要求,当用户点开编辑窗口进行修改并没有保存时,点击编辑窗口以外的任何地方,阻止默认事件,弹窗令用户选择是否保存后再执行默认事件。
想来想去没有很好的解决办法,求一个思路.
问题主要在于不是关闭浏览器触发弹框,而是点击页面上的非编辑窗口部分时都要触发,而这些部分里有各种绑定事件、链接之类的。
原本的想法是能不能通过给编辑窗口添加失焦事件,弹出自定义confirm,根据confirm的选择判断是否执行默认事件,结果还是放弃了…
最后只能给每个链接和事件添加判断方法,传入默认执行函数作为回调参数
类似这样
立即学习“Java免费学习笔记(深入)”;
<a href="index.php">首页</a>
改为
<div id="myconfirm">
<p>确认离开?</p>
<button id="yes">是</button><button id="no">否</button>
</div>
<a href="javascript:void(0)">首页</a>
<script>
$('a').click(function(){
myconfirm(function(){
window.location.href="index.php";
},function(){
return false;
});
});
function myconfirm(fun_yes,fun_no){
$('#yes').unbind();
$('#no').unbind();
$('#yes').click(function(){
fun_yes();
});
$('#no').click(function(){
fun_no();
});
$('#myconfirm').show();
}
</script>
一个很流行的对话框插件,
http://aui.github.io/artDialo...
监听浏览器关闭事件
给编辑器绑定onblur事件不行吗?











