ブートストラップモーダル閉じるボタン

ジャリス・カノ

ブートストラップのクローズモーダルに問題があります。データを含むモーダルウィンドウを開いたとき(トリガーボタンに基づいてモーダルコンテンツを変更)。これはhttp://getbootstrap.com/javascript/#modalsの例です

<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@mdo">Open modal for @mdo</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@fat">Open modal for @fat</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@getbootstrap">Open modal for @getbootstrap</button>
...more buttons...

<div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="exampleModalLabel">New message</h4>
      </div>
      <div class="modal-body">
        <form>
          <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>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" id="btnclose" data-dismiss="modal">Close</button>
        <button type="button" id="btnsend" class="btn btn-primary">Send message</button>
      </div>
    </div>
  </div>
</div>

これは問題ありませんが、モーダルを閉じて別のボタンを使用して開くと、送信ボタンをクリックすると、最初のモーダルとこのモーダルの受信者の値がコンソールに出力されます。しかし、最後の受信者の値を印刷するだけで済みます。以前のモーダルクローズのイベントがスタックされた理由がわかりません。これは、両方のボタンのjQueryコードです。

    $('#exampleModal').on('show.bs.modal', function (event) {

    var button = $(event.relatedTarget) // Button that triggered the modal
    var recipient = button.data('whatever') // Extract info from data-* attributes
    // If necessary, you could initiate an AJAX request here (and then do the updating in a callback).
    // Update the modal's content. We'll use jQuery here, but you could use a data binding library or other methods instead.
    var modal = $(this)
    modal.find('.modal-title').text('New message to ' + recipient)
    modal.find('.modal-body input').val(recipient)

    $("#btnsend").one("click", function(){
        console.log('Pinchado')
      console.log(recipient)
    })

    $("#btnclose").one("click", function(){
        console.log('Cerrando...')
    })

    $('#exampleModal').on('hidden.bs.modal', function (e) {
      console.log('Cerrada');
    })

  })

どうもありがとうございました。誰かが私を助けてくれることを願っています。https://jsfiddle.net/DTcHh/28480/

シャリン・パテル

これはあなたまたはあなたがこれをしている従来の方法を言うことができる古い方法です。それでも答えはあります。非表示をバインドし、show eventbindの外側のeventdsをクリックするだけです。

$('#exampleModal').on('show.bs.modal', function(event) {

   var button = $(event.relatedTarget) // Button that triggered the modal
   var recipient = button.data('whatever') // Extract info from data-* attributes
     // If necessary, you could initiate an AJAX request here (and then do the updating in a callback).
     // Update the modal's content. We'll use jQuery here, but you could use a data binding library or other methods instead.
   var modal = $(this)
   modal.find('.modal-title').text('New message to ' + recipient)
   modal.find('.modal-body input').val(recipient)
 })
 
 $("#btnsend").on("click", function() {
     console.log('Pinchado')
     console.log(recipient)
   })

   $("#btnclose").on("click", function() {
     console.log('Cerrando...')
   })

   $('#exampleModal').on('hidden.bs.modal', function(e) {
     console.log('Cerrada');
   })
<!-- 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" data-toggle="modal" data-target="#exampleModal" data-whatever="@mdo">Open modal for @mdo</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@fat">Open modal for @fat</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@getbootstrap">Open modal for @getbootstrap</button>
...more buttons...

<div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span>
        </button>
        <h4 class="modal-title" id="exampleModalLabel">New message</h4>
      </div>
      <div class="modal-body">
        <form>
          <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>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" id="btnclose" data-dismiss="modal">Close</button>
        <button type="button" id="btnsend" class="btn btn-primary">Send message</button>
      </div>
    </div>
  </div>
</div>

以下に示すのは、それを行うための現代的な方法です。モーダルを動的に作成する方法の詳細については、このリンク参照してください

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) {
      $('#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>

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

バックボーンブートストラップモーダルハンドルを閉じる

分類Dev

ブートストラップモーダルを閉じる

分類Dev

ブートストラップモーダル-「行動を促す」ボタンがクリックされたときにモーダルを閉じる

分類Dev

ブートストラップモーダルボックスの閉じるボタンが機能しない

分類Dev

ボタンがモーダルボディ内に配置されていない場合は、ブートストラップモーダルを閉じます

分類Dev

ブートストラップモーダルは、閉じるボタンのフォーカスを復元します

分類Dev

ブートストラップモーダルウィンドウの閉じるボタンの色を変更する

分類Dev

送信ボタンのクリック時にブートストラップモーダルが閉じないようにする

分類Dev

ajax呼び出しによって開かれたブートストラップ4モーダル-閉じるボタンが機能しない

分類Dev

Angularブートストラップ:モーダルを閉じる方法

分類Dev

特定のブートストラップモーダルを閉じる

分類Dev

ブートストラップモーダルの「x」(閉じる)ボタンを取得して、モーダルを閉じる代わりにjavascript関数を呼び出すことはできますか?

分類Dev

ブートストラップ3モーダルを閉じた後のスクロールボディ

分類Dev

ブートストラップモーダルウィンドウをangularjsから閉じる方法

分類Dev

ブートストラップDateTimePicker閉じるボタンの位置

分類Dev

ブートストラップでモーダルを閉じた後、モーダルトリガーボタンのフォーカスを解除するにはどうすればよいですか?

分類Dev

モーダルが閉じた後、ブートストラップモーダルのトグルボタンにフォーカスしないようにするにはどうすればよいですか?

分類Dev

プログラムでモーダルボトムシートをフラッターで閉じる

分類Dev

ASP.Netボタンクリックのポストバック時にモーダルポップアップ(ブートストラップ)ウィンドウが閉じないようにする

分類Dev

ブートストラップnavbar-toggleボタンを避けて、モバイルで開いているサブメニューを閉じます

分類Dev

onclickブートストラップを閉じないボタンを閉じる

分類Dev

AngularJSブートストラップモーダル結果を閉じずに

分類Dev

UIブートストラップモーダルが閉じません。AngularJS

分類Dev

ファイルのダウンロード後にブートストラップモーダルポップアップを閉じる方法

分類Dev

Angular2-デフォルトのブートストラップモーダルを開く/閉じる

分類Dev

データの却下時にブートストラップモーダルが閉じない(Rails)

分類Dev

textareaにフォーカスすると、ブートストラップモーダルが閉じます

分類Dev

ブートストラップポップオーバー閉じるボタンが機能しない

分類Dev

onClickボタンとブートストラップモーダルが内部にあるonClickテーブル行

Related 関連記事

  1. 1

    バックボーンブートストラップモーダルハンドルを閉じる

  2. 2

    ブートストラップモーダルを閉じる

  3. 3

    ブートストラップモーダル-「行動を促す」ボタンがクリックされたときにモーダルを閉じる

  4. 4

    ブートストラップモーダルボックスの閉じるボタンが機能しない

  5. 5

    ボタンがモーダルボディ内に配置されていない場合は、ブートストラップモーダルを閉じます

  6. 6

    ブートストラップモーダルは、閉じるボタンのフォーカスを復元します

  7. 7

    ブートストラップモーダルウィンドウの閉じるボタンの色を変更する

  8. 8

    送信ボタンのクリック時にブートストラップモーダルが閉じないようにする

  9. 9

    ajax呼び出しによって開かれたブートストラップ4モーダル-閉じるボタンが機能しない

  10. 10

    Angularブートストラップ:モーダルを閉じる方法

  11. 11

    特定のブートストラップモーダルを閉じる

  12. 12

    ブートストラップモーダルの「x」(閉じる)ボタンを取得して、モーダルを閉じる代わりにjavascript関数を呼び出すことはできますか?

  13. 13

    ブートストラップ3モーダルを閉じた後のスクロールボディ

  14. 14

    ブートストラップモーダルウィンドウをangularjsから閉じる方法

  15. 15

    ブートストラップDateTimePicker閉じるボタンの位置

  16. 16

    ブートストラップでモーダルを閉じた後、モーダルトリガーボタンのフォーカスを解除するにはどうすればよいですか?

  17. 17

    モーダルが閉じた後、ブートストラップモーダルのトグルボタンにフォーカスしないようにするにはどうすればよいですか?

  18. 18

    プログラムでモーダルボトムシートをフラッターで閉じる

  19. 19

    ASP.Netボタンクリックのポストバック時にモーダルポップアップ(ブートストラップ)ウィンドウが閉じないようにする

  20. 20

    ブートストラップnavbar-toggleボタンを避けて、モバイルで開いているサブメニューを閉じます

  21. 21

    onclickブートストラップを閉じないボタンを閉じる

  22. 22

    AngularJSブートストラップモーダル結果を閉じずに

  23. 23

    UIブートストラップモーダルが閉じません。AngularJS

  24. 24

    ファイルのダウンロード後にブートストラップモーダルポップアップを閉じる方法

  25. 25

    Angular2-デフォルトのブートストラップモーダルを開く/閉じる

  26. 26

    データの却下時にブートストラップモーダルが閉じない(Rails)

  27. 27

    textareaにフォーカスすると、ブートストラップモーダルが閉じます

  28. 28

    ブートストラップポップオーバー閉じるボタンが機能しない

  29. 29

    onClickボタンとブートストラップモーダルが内部にあるonClickテーブル行

ホットタグ

アーカイブ