我有一个内容是动态的模态,并且这个模态有一个拒绝按钮。
这个模态本身是通过链接动态生成的,所以我必须使用委托
$( "body" ).delegate( ".reject", "click", function(e) {
$(".modalInfo").hide();
$(".modalReject").show();
someFunction();
});
假设用户单击拒绝按钮并关闭模式。然后她加载了一个新的模态,所以这个模态的上下文发生了变化并且有一个新的拒绝按钮。
当用户在这个新的上下文中再次点击拒绝按钮时, someFunction() 以某种方式执行了两次——一次来自原始点击,第二次来自这个新的点击。再次关闭模式,加载一个新的上下文,执行点击,瞧……得到了三个 someFunction() 调用!
经过一番研究,我发现:当替换元素时,事件和数据会发生什么
如何防止这种情况?