我的 html 页面上有一个用于更新一些自定义数据的表单。在提交表单之前,我想向用户询问确认消息,如果他更新了表单中的数据并单击同一 html 页面上的其他链接。
我是如何实现的:
我已经制作了布尔变量来保持用户是否更新了任何字段的状态。而且我使用 .html 页面中的所有标签绑定click
事件。这样当用户单击页面上的任何锚标记时,我将检查状态变量是否为真(值已更改)。如果是真的,我想停止重定向并要求确认。anchor
jquery
我已经做到了这一点。但问题是即使用户点击cancel
确认框,我也无法停止重定向。
这是代码
$(document).ready(function(){
GLOBAL_NAMESPACE.value_changed = false;
$("[id^='id_']").live('change', function (){
GLOBAL_NAMESPACE.value_changed = true;
});
});
$('a').bind('click',function (e) {
e.preventDefault();
if (GLOBAL_NAMESPACE.customize_option_changed){
var res = confirm('you have unsaved changes. Do you want to continue?');
if(res){
GLOBAL_NAMESPACE.customize_option_changed = false;
$(this).click();
}else{
console.log('stay on same page...');
// Problem: user redirects to the clicked link even if he reaches here
}
}
});
我的实现思路有问题吗?这段代码有什么问题?或者有没有更好的方法来做到这一点?