可靠地隐藏引导模式

Reliably hide Bootstrap modal

本文关键字:模式 隐藏      更新时间:2023-09-26

我正在使用Bootstrap 2.3.2,我正在使用这样的模式对话框:

<div id="notice1" class="modal hide fade">
    <div class="modal-body">
        <h4>This is a dialog for user...</h4>
    </div>
    ...
</div>

var notice1 = $("#notice1");
notice1.modal({
    keyboard: false,
    backdrop: "static",
    show: false
});
// Show the dialog
notice1.modal("show");
// Close the dialog
notice1.modal("hide");

大多数情况下,上述工作正常,模式对话框以编程方式打开和关闭。但是,在极少数情况下,尽管删除了深色背景,但调用.modal("hide")根本不会关闭对话框。

这是一个巨大的潜在问题,因为对话框可能会卡在屏幕上并阻止部分内容。

有没有可靠的方法可以确保在调用.modal("hide")后始终关闭对话框?或者更好的是,我们如何确保Bootstrap一致的hide行为?我不想从 DOM 中完全删除对话框,因为相同的对话框可能会在页面上重复使用。

可以使用以下代码隐藏模式。

 $("#notice1").hide();
 $(".modal-backdrop").hide();

根据文档: http://getbootstrap.com/2.3.2/javascript.html#modals

可以捕获hidden事件并强制使用 display:none 属性。

    notice1.on('hidden', function () {
      $(this).css("display", "none")
    })

我正在使用1.9.x,下面的代码工作。

$("#yourModalWindow").modal('hide');