创建自定义JQuery插件时会出现问题,该插件将显示Bootstrap模式对话框。自定义插件需要回调函数作为参数。
问题是当模态对话框调用两次,回调也调用两次,依此类推。
这里是代码:
HTML
<a href="#" class="confirm_delete">test modal</a>
<div class="modal fade" id="general_modal" tabindex="-1" role="dialog" aria-labelledby="general_modalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title" id="general_modal_title">Set Title Here</h4>
</div>
<div class="modal-body">set modal content here</div>
<div class="modal-footer">
<button type="button" class="btn btn-default close_button" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary action_button">Save changes</button>
</div>
</div>
</div>
的Javascript
(function ($) {
$.fn.showDialog = function (options, callback) {
$('#general_modal').modal();
$('#general_modal .action_button').on('click', function () {
callback();
});
}
}(jQuery));
$('.confirm_delete').click(function (e) {
e.preventDefault();
$(this).showDialog(null, function () {
alert('xxx');
});
});
答案 0 :(得分:12)
每次运行showDialog
时,您都会重新绑定模式并单击事件。以下是您每次都可以阻止重新附加事件的方法:
(function ($) {
$.fn.showDialog = function (options, callback) {
$('#general_modal').unbind().modal();
$('#general_modal .action_button').unbind().on('click', function () {
callback();
});
}
}(jQuery));
$('.confirm_delete').click(function (e) {
e.preventDefault();
$(this).showDialog(null, function () {
alert('xxx');
});
});
答案 1 :(得分:1)
您可以针对on()调用one():
$('#general_modal .action_button').unbind().one('click', function () {
根据文件:
.one()方法与.on()相同,除了a的处理程序 给定的元素和事件类型在第一次调用后未绑定。 例如: