Bootstrap モーダルボックス

 

Bootstrap モーダル(Modal)プラグイン

モーダル(Modal)は、親ウィンドウの上に重ねて表示される子ウィンドウです。通常、別のソースからのコンテンツを表示したり、親ウィンドウから移動せずにインタラクションを行ったりするために使用されます。

1. Bootstrap モーダル(Modal)プラグイン

Bootstrap モーダルプラグインは、モーダルウィンドウを作成するために使用されます。モーダルウィンドウは、親ウィンドウの上に重ねて表示される子ウィンドウで、ユーザーの注意を引き付けたり、追加情報を提供したりするために使用されます。

2. 使い方

Bootstrap モーダルは、data 属性または JavaScript を使用して呼び出すことができます。

2.1 HTML 構造

基本的なモーダルの HTML 構造は次のとおりです。


<div class="modal" tabindex="-1" role="dialog" id="myModal">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">モーダルのタイトル</h5>
        <button type="button" class="close" data-dismiss="modal" aria-label="閉じる">
          <span aria-hidden="true">×</span>
        </button>
      </div>
      <div class="modal-body">
        <p>モーダルのコンテンツ...</p>
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-secondary" data-dismiss="modal">閉じる</button>
        <button type="button" class="btn btn-primary">保存</button>
      </div>
    </div>
  </div>
</div> 

2.2 data 属性を使用した呼び出し

モーダルを呼び出すには、モーダルのトリガーとなる要素に data-toggle="modal"data-target="#myModal" を追加します。data-target 属性には、モーダルの ID を指定します。


<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#myModal">
  モーダルを表示
</button>

2.3 JavaScript を使用した呼び出し

JavaScript を使用してモーダルを表示するには、次のように記述します。


$('#myModal').modal('show');

3. モーダルオプション

モーダルの動作は、data 属性または JavaScript でオプションを設定することでカスタマイズできます。

オプション 説明 デフォルト値
backdrop モーダルの背後をクリックしたときの動作を指定します。true の場合、背後をクリックするとモーダルが閉じます。false の場合、背後をクリックしてもモーダルは閉じません。'static' の場合、背後をクリックしてもモーダルは閉じませんが、モーダル内の要素は引き続き操作できます。 true
keyboard Esc キーを押したときにモーダルを閉じるかどうかを指定します。 true
focus モーダルが表示されたときに、モーダルにフォーカスを当てるかどうかを指定します。 true
show モーダルをデフォルトで表示するかどうかを指定します。 true

4. モーダルイベント

モーダルは、表示状態が変化したときにイベントを発生させます。

イベント 説明
show.bs.modal モーダルの表示が開始されたときに発生します。
shown.bs.modal モーダルの表示が完了したときに発生します。
hide.bs.modal モーダルの非表示が開始されたときに発生します。
hidden.bs.modal モーダルの非表示が完了したときに発生します。

5. JavaScript を使用したモーダルの操作

JavaScript を使用してモーダルを操作するには、次のようなメソッドを使用します。

メソッド 説明
.modal(options) モーダルを初期化またはオプションを変更します。
.modal('toggle') モーダルの表示状態をトグルします。
.modal('show') モーダルを表示します。
.modal('hide') モーダルを非表示にします。
.modal('handleUpdate') モーダルの位置とサイズを手動で更新します。

6. モーダルインスタンス

Modal.getInstance(element) メソッドを使用すると、指定した要素に関連付けられているモーダルインスタンスを取得できます。

7. 静的メソッド

Bootstrap モーダルプラグインは、次の静的メソッドを提供します。

メソッド 説明
Modal.getInstance(element) 指定した要素に関連付けられているモーダルインスタンスを取得します。
Modal.VERSION Bootstrap モーダルプラグインのバージョン番号を取得します。

8. デフォルト設定

Bootstrap モーダルプラグインのデフォルトの JavaScript 設定は次のとおりです。


$.fn.modal.Constructor.Default = {
  backdrop: true,
  keyboard: true,
  focus: true,
  show: true
}

モーダルに関するQ&A

Q1: モーダルが正しく表示されません。

A1: まず、HTML の構造が正しいことを確認してください。特に、モーダルの ID と、モーダルを呼び出す要素の data-target 属性が一致していることを確認してください。また、必要な JavaScript ファイルが正しく読み込まれていることを確認してください。

Q2: モーダルを閉じずに、モーダル内のフォームを送信するにはどうすればよいですか?

A2: フォームの送信ボタンの data-dismiss="modal" 属性を削除し、代わりに JavaScript を使用してフォームを送信し、モーダルを閉じます。Ajax を使用してフォームを送信する場合は、送信が完了した後に JavaScript でモーダルを閉じることができます。

Q3: モーダルのコンテンツを動的に変更するにはどうすればよいですか?

A3: JavaScript を使用して、モーダルのコンテンツを動的に変更できます。show.bs.modal イベントまたは shown.bs.modal イベントで、モーダルのコンテンツを取得し、必要な内容に置き換えます。