我读了Bootstrap网站上的帖子,疯狂地谷歌了一下——但我肯定找不到一个简单的答案……

我有一个Bootstrap模式,我从一个link_to helper像这样打开:

<%= link_to "New Contact", new_contact_path, {remote: true, 'data-toggle' => 'modal', 'data-target' => "#myModal",  class: "btn btn-primary"} %>

在我的ContactsController中。创建动作,我有创建联系人的代码,然后传递给create.js.erb。在create.js。erb,我有一些错误处理代码(ruby和javascript的混合)。如果一切顺利,我想关闭模态。

这就是我遇到麻烦的地方。当一切顺利的时候,我似乎不能放弃模态。

我尝试了$('#myModal').modal('hide');这没有任何影响。我还尝试了$('#myModal').hide();这导致模态解散,但留下背景。

关于如何在create.js.erb中关闭模式和/或解散背景,有什么指导吗?

Edit

下面是myModal的标记:

<div class="modal hide" id="myModal" >
  <div class="modal-header">
    <a class="close" data-dismiss="modal">×</a>
    <h3>Add Contact</h3>
    <div id="errors_notification">
    </div>
  </div>
  <div class="modal-body">
    <%= form_for :contact, url: contacts_path, remote: true do |f| %>  
      <%= f.text_field :first_name, placeholder: "first name" %>
      <%= f.text_field :last_name, placeholder: "last name" %>
      <br>
      <%= f.submit "Save", name: 'save', class: "btn btn-primary" %>
      <a class="close btn" data-dismiss="modal">Cancel</a>
    <% end %>
  </div>
  <div class="modal-footer">
  </div>
</div>

当前回答

我也遇到过同样的问题,经过一些实验,我找到了一个解决方案。在我的点击处理程序中,我需要停止事件冒泡,如下所示:

$("a.close").on("click", function(e){
  $("#modal").modal("hide");
  e.stopPropagation();
});

其他回答

. getelementbyid (closeButton) .click ();//添加data-dismiss="modal"属性到modal中的元素,并给它这个id

我有更好的运气在“显示”回调发生后进行调用:

$('#myModal').on('shown', function () {
      $('#myModal').modal('hide');
})

这确保了模态在调用hide()之前完成加载。

隐藏模式背景工作,但随后打开模式和背景不像它应该隐藏。我发现这种方法始终有效:

// SHOW
$('#myModal').modal('show')
$('.modal-backdrop').show();

// HIDE
$('#myModal').modal('hide');
$('.modal-backdrop').hide();

我遇到了同样的错误,这行代码真的帮助了我。

$("[data-dismiss=modal]").trigger({ type: "click" });

$(" #模态”).modal(隐藏的);它的变体并不适用于我,除非我在取消按钮上有data-dismiss="modal"作为属性。像你一样,我的需求是可能关闭/可能-不关闭基于一些额外的逻辑,所以直接点击一个带有data-dismiss="modal"的链接是不行的。我最终有一个隐藏的按钮data-dismiss="modal",我可以通过编程调用点击处理程序,所以

<a id="hidden-cancel" class="hide" data-dismiss="modal"></a>
<a class="close btn">Cancel</a>

然后在点击处理程序中,当你需要关闭模态时取消

$('#hidden-cancel').click();