【问题标题】:Removing bootstrap Modal from DOM从 DOM 中移除引导模式
【发布时间】:2017-01-23 17:36:44
【问题描述】:

我正在编写一段代码,以便在用户通过点击触发事件后动态加载我的部分内容。

案例场景是:当用户点击帖子时,会打开一个modal并显示详细视图,这是使用链接中的slug动态生成的内容。但是,当用户关闭modal 时,我需要从DOM 中删除模式。目前我只能hide它,但我需要删除它。

这是我的代码。

PHP Laravel HTML 标记():

<div class="content-blocks blog hidex">

        <section class="content">
            <div class="block-content">
                <h3 class="block-title">My Blog</h3>
                <div id="post-list" class="col-md-10 col-md-offset-1">

                    {% set posts = blogPosts.posts %}

                    {% for post in posts %}
                    <div class="post">

                        <div class="post-thumbnail">
                            {% if post.featured_images.count %}
                            {% set image = post.featured_images|first %}
                            <a class="open-post" href="{{'blog-post'|page}}">
                                <img
                                        data-src="{{ image.filename }}"
                                        src="{{ image.path }}"
                                        alt="{{ image.description }}"
                                        style="max-width: 100%"/>

                            </a>
                            {% endif %}
                        </div>
                        <div class="post-title">
                            <a class="open-post" href="{{ post.url }}"><h2>{{ post.title }}</h2></a>
                            <p class="post-info">


                                <span class="post-author">Posted by {{ post.user.first_name}} </span>
                                <span class="slash"></span>
                                <span class="post-date">on {{ post.published_at|date('M d, Y') }}</span>
                                <span class="slash"></span>
                                {% if post.categories.count %} in {% endif %}
                                {% for category in post.categories %}
                                <span class="post-category">{{ category.name }}</span>
                                {% if not loop.last %}, {% endif %}
                                {% endfor %}
                            </p>
                        </div>
                        <div class="post-body">
                            <p>{{ post.summary }}</p>
                            <a class="btn open-post" href="{{ post.url }}">Read More</a>
                        </div>
                    </div>
                    {% endfor %}

                    <div class="text-center">
                        {% if posts.lastPage > 1 %}
                        <ul class="pagination">
                            {% if posts.currentPage > 1 %}
                            <li>
                                <a href="{{ this.page.baseFileName|page({ (pageParam): (posts.currentPage-1) }) }}"
                                   aria-label="Previous">
                                    <span aria-hidden="true">&laquo;</span>
                                </a></li>
                            {% endif %}

                            {% for page in 1..posts.lastPage %}
                            <li class="{{ posts.currentPage == page ? 'active' : null }}">
                                <a href="{{ this.page.baseFileName|page({ (pageParam): page }) }}">{{ page }}</a>
                            </li>
                            {% endfor %}

                            {% if posts.lastPage > posts.currentPage %}
                            <li><a href="{{ this.page.baseFileName|page({ (pageParam): (posts.currentPage+1) }) }}"
                                   aria-label="Next">
                                <span aria-hidden="true">&raquo;</span>
                            </a>
                            </li>
                            {% endif %}
                        </ul>
                        {% endif %}
                    </div>
                </div>
            </div>
        </section>
    </div>

JavaScript:

//Blog post Modal
    $('.open-post').on('click', function(){
        var postUrl = $(this).attr("href");

        var post = '<div class="modal" id="post-modal"><div class="inline-menu-container"><a id="modal-close" class="close" data-dismiss="modal"><span aria-hidden="true">&times;</span></a></div><div class="modal-dialog"><div class="modal-content"></div></div></div>';

        $(post).modal({
          remote: postUrl
        })

        return false;
    });
// close the modal
   $('#close').on( 'click', function() {
      $('.name-block').removeClass('reverse');
      $('.name-block-container').removeClass('reverse');
      $('.menu-blocks').removeClass('hidex');
      $('.content-blocks').removeClass('showx');
      $('.content-blocks').addClass('hidex');
      $('.inline-menu-container').removeClass('showx');
      $('.inline-menu-container').addClass('hidex');
      $('.menu-item').removeClass('active');
    });

DOM 中 Javascript 代码的结果:

<div class="modal in" id="post-modal" style="display: block; padding-left: 0px;">
    <div class="inline-menu-container">
    <a id="modal-close" class="close" data-dismiss="modal"><span aria-hidden="true">×</span></a>
</div>
<div class="modal-dialog">
   <div class="modal-content">
   /// all the dynamic content in the modal
   </div>
</div>

现在我需要在不刷新页面的情况下删除此结果。 更新: 这是关闭modal 后在 Inspect 中的 HTML 的外观:

注意: 我尝试使用 #post-modal id 从 DOM 中删除模态内容,但没有成功。此外,我还没有找到使用Delegate 的示例,而模态元素和内容在加载“DOM”后完全由 javascript 添加。

【问题讨论】:

  • 你为什么不试试css? .modal-dialog{ display: none !important; }
  • @I.G.Pascual 我在模式中有一个 JQuery Sildeshow,由于 DOM 中有多个元素,每当我第二次打开页面时都会引发异常。所以我需要从 DOM 中删除模式。
  • 那么 javascript 就是答案
  • 你试过$(function(){ $("#post-modal").remove(); $(".modal-dialog").remove(); });吗?
  • @I.G.Pascual 我使用了你的函数,比如$(document) .on('hidden.bs.modal', '.modal', function () { $("#post-modal").remove(); $(".modal-dialog").remove(); });,它起作用了

标签: javascript html twitter-bootstrap bootstrap-modal


【解决方案1】:

Bind an event 然后remove()

$('.modal').on('hidden.bs.modal', function () {
    $(this).remove();
});

$('.modal').on('hidden.bs.modal', function () {
    $('.modal').remove();
});

【讨论】:

  • 快速提问。我以前试过这样 $('#blog-post').on('hidden.bs.modal', function () { $(this).remove(); });但没有用。你能告诉我我应该为#myModal 使用哪个 ID,因为我正在使用 JS 将整个模态添加到 DOM,正如我在帖子中解释的那样
  • 我试过了,但它并没有从 DOM 中删除模式。我添加了 Inspect 的图像以使其更清晰。图像通过隐藏模式显示关闭模式后的代码。我还添加了我在 JS 中使用的 JS 代码。
  • 您有多个具有该 ID 的模式。它可能正在工作,但删除了第三个......或者由于多个 ID,它根本不工作。
  • 这就是为什么我正在寻找一种方法来删除它而不是隐藏它。创建这些多个模式是因为我只隐藏它们而不删除它们。我上传了图片以显示发生了什么以及如何解决
  • 这是生活在某个地方吗?否则我想我不能再帮你了。
【解决方案2】:

感谢I.G. PascualSerg Chernata,这是解决方案:

Javascript 代码:

$(document).on('hidden.bs.modal', '.modal', function () { $("#post-modal").remove(); $(".modal-dialog").remove(); });

【讨论】:

    【解决方案3】:

    你可以试试这个

    $(modal).modal().on('hidden.bs.modal',function(e){
        e.target.remove();
    })
    

    您可以直接在初始化本身上添加隐藏事件。所以你不必每次都单独触发。

    【讨论】:

      【解决方案4】:

      下面给出的 sn-p 将告诉你如何做你想做的事情,而不必做任何额外的事情,甚至不需要编写传统的引导模式代码。

      如需进一步参考,您还可以访问this link。它将向您展示如何以最小的努力动态创建模态。

      function open_modal(name) {
      
        var message = $('#frm_1');
        BootstrapDialog.show({
          title: 'New message to ' + name,
          message: $('#frm_1'),
          onshown: function() {
            $('#recipient-name').val(name);
          },
          onhide: function(dialog) {
            console.log('Cerrada');
            $('#hidden-div').append(message);
          },
          buttons: [{
            label: 'Close',
            action: function(dialog) {
              dialog.close();
            }
          }, {
            label: 'Send message',
            cssClass: 'btn btn-primary',
            action: function(dialog) {
              // Do whatever send message does, here
            }
          }]
        });
      
      
      
      }
      <!-- Latest compiled and minified CSS -->
      <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap3-dialog/1.34.7/css/bootstrap-dialog.min.css">
      
      <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
      
      
      <!-- jQuery library -->
      <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
      
      <!-- Latest compiled JavaScript -->
      <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
      
      <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap3-dialog/1.34.7/js/bootstrap-dialog.min.js"></script>
      
      <button type="button" class="btn btn-primary" onclick="open_modal('@mdo')">Open modal for @mdo</button>
      <button type="button" class="btn btn-primary" onclick="open_modal('@fat')">Open modal for @fat</button>
      <button type="button" class="btn btn-primary" onclick="open_modal('@getbootstrap')">Open modal for @getbootstrap</button>
      
      
      <div id="hidden-div" style="display : none">
      
        <form id="frm_1">
          <div class="form-group">
            <label for="recipient-name" class="control-label">Recipient:</label>
            <input type="text" class="form-control" id="recipient-name">
          </div>
          <div class="form-group">
            <label for="message-text" class="control-label">Message:</label>
            <textarea class="form-control" id="message-text"></textarea>
          </div>
        </form>
      </div>

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2020-12-06
        • 1970-01-01
        • 2012-08-11
        • 2017-11-27
        • 2016-03-04
        • 2016-04-03
        • 2015-03-23
        相关资源
        最近更新 更多