ドロップダウン
Bootstrap ドロップダウン プラグインを使用して、リンクなどのリストを表示するコンテキスト オーバーレイを切り替えます。
ドロップダウンは、リンクのリストなどを表示するための切り替え可能なコンテキスト オーバーレイです。それらは、含まれている Bootstrap ドロップダウン JavaScript プラグインを使用してインタラクティブに作成されます。ホバリングではなく、クリックすることで切り替えられます。これは意図的な設計上の決定です。
ドロップダウンは、動的ポジショニングとビューポート検出を提供するサードパーティ ライブラリPopper.jsに基づいて構築されています。Bootstrap の JavaScript の前に必ずpopper.min.jsを含めるか、 Popper.js を含むbootstrap.bundle.min.js
/bootstrap.bundle.js
を使用してください。Popper.js は、動的な配置が必要ないため、navbars にドロップダウンを配置するために使用されません。
JavaScript をソースからビルドする場合はutil.js
、 .
WAI ARIA標準は実際の widget を定義しますrole="menu"
が、これはアクションまたは機能をトリガーするアプリケーションのようなメニューに固有のものです。ARIAメニューには、メニュー項目、チェックボックス メニュー項目、ラジオ ボタン メニュー項目、ラジオ ボタン グループ、およびサブメニューのみを含めることができます。
一方、Bootstrap のドロップダウンは、汎用的で、さまざまな状況やマークアップ構造に適用できるように設計されています。たとえば、検索フィールドやログイン フォームなど、追加の入力やフォーム コントロールを含むドロップダウンを作成できます。このため、Bootstrap は、真のARIAメニューに必要なrole
およびaria-
属性のいずれも期待 (または自動的に追加) しません。作成者は、これらのより具体的な属性を自分で含める必要があります。
ただし、Bootstrap は.dropdown-item
、カーソル キーを使用して個々の要素間を移動し、ESCキーでメニューを閉じる機能など、ほとんどの標準的なキーボード メニュー操作の組み込みサポートを追加します。
ドロップダウンのトグル (ボタンまたはリンク) とドロップダウン メニューを.dropdown
、または を宣言する別の要素でラップしposition: relative;
ます。<a>
ドロップダウンは、または要素からトリガーし<button>
て、潜在的なニーズにより適合させることができます。
いくつかのマークアップを変更して、任意の単一.btn
をドロップダウン トグルに変えることができます。<button>
どちらの要素でも動作させる方法は次のとおりです。
<div class="dropdown">
<button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown button
</button>
<div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
</div>
</div>
そして<a>
要素で:
<div class="dropdown show">
<a class="btn btn-secondary dropdown-toggle" href="#" role="button" id="dropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown link
</a>
<div class="dropdown-menu" aria-labelledby="dropdownMenuLink">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
</div>
</div>
最良の部分は、ボタンのバリアントでもこれを実行できることです。
同様に、単一ボタン ドロップダウンと実質的に同じマークアップを使用して分割ボタン ドロップダウンを作成しますが.dropdown-toggle-split
、ドロップダウン キャレットの周囲に適切なスペースを追加します。
この追加のクラスを使用してpadding
、キャレットの両側の水平方向を 25%縮小し、margin-left
通常のボタン ドロップダウンに追加された を削除します。これらの追加の変更により、キャレットが分割ボタンの中央に配置され、メイン ボタンの横により適切なサイズのヒット領域が提供されます。
ボタン ドロップダウンは、デフォルトのドロップダウン ボタンやスプリット ドロップダウン ボタンなど、あらゆるサイズのボタンで機能します。
.dropup
親要素に追加して、要素の上のドロップダウン メニューをトリガーします。
.dropright
親要素に追加して、要素の右側にあるドロップダウン メニューをトリガーします。
.dropleft
親要素に追加して、要素の左側にあるドロップダウン メニューをトリガーします。
従来、ドロップダウン メニューのコンテンツはリンクでなければなりませんでしたが、v4 ではそうではなくなりました。<button>
オプションで、sだけでなく、ドロップダウンで要素を使用できるようになりまし<a>
た。
<div class="dropdown">
<button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenu2" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Dropdown
</button>
<div class="dropdown-menu" aria-labelledby="dropdownMenu2">
<button class="dropdown-item" type="button">Action</button>
<button class="dropdown-item" type="button">Another action</button>
<button class="dropdown-item" type="button">Something else here</button>
</div>
</div>
デフォルトでは、ドロップダウン メニューは親の左側に沿って上から 100% の位置に自動的に配置されます。ドロップダウン メニューを右揃え.dropdown-menu-right
にするには、aに追加します。.dropdown-menu
注意喚起!ドロップダウンは、Popper.js のおかげで配置されます (ナビゲーション バーに含まれている場合を除く)。
<div class="btn-group">
<button type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Right-aligned menu
</button>
<div class="dropdown-menu dropdown-menu-right">
<button class="dropdown-item" type="button">Action</button>
<button class="dropdown-item" type="button">Another action</button>
<button class="dropdown-item" type="button">Something else here</button>
</div>
</div>
ヘッダーを追加して、ドロップダウン メニューのアクションのセクションにラベルを付けます。
<div class="dropdown-menu">
<h6 class="dropdown-header">Dropdown header</h6>
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
</div>
関連するメニュー項目のグループを仕切りで分けます。
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="#">Separated link</a>
</div>
ドロップダウン メニュー内にフォームを配置するか、フォームをドロップダウン メニューにして、マージンまたはパディング ユーティリティを使用して、必要な負のスペースをフォームに与えます。
<div class="dropdown-menu">
<form class="px-4 py-3">
<div class="form-group">
<label for="exampleDropdownFormEmail1">Email address</label>
<input type="email" class="form-control" id="exampleDropdownFormEmail1" placeholder="[email protected]">
</div>
<div class="form-group">
<label for="exampleDropdownFormPassword1">Password</label>
<input type="password" class="form-control" id="exampleDropdownFormPassword1" placeholder="Password">
</div>
<div class="form-check">
<input type="checkbox" class="form-check-input" id="dropdownCheck">
<label class="form-check-label" for="dropdownCheck">
Remember me
</label>
</div>
<button type="submit" class="btn btn-primary">Sign in</button>
</form>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="#">New around here? Sign up</a>
<a class="dropdown-item" href="#">Forgot password?</a>
</div>
<form class="dropdown-menu p-4">
<div class="form-group">
<label for="exampleDropdownFormEmail2">Email address</label>
<input type="email" class="form-control" id="exampleDropdownFormEmail2" placeholder="[email protected]">
</div>
<div class="form-group">
<label for="exampleDropdownFormPassword2">Password</label>
<input type="password" class="form-control" id="exampleDropdownFormPassword2" placeholder="Password">
</div>
<div class="form-check">
<input type="checkbox" class="form-check-input" id="dropdownCheck2">
<label class="form-check-label" for="dropdownCheck2">
Remember me
</label>
</div>
<button type="submit" class="btn btn-primary">Sign in</button>
</form>
.active
ドロップダウンのアイテムに追加して、それらをアクティブとしてスタイルします。
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Regular link</a>
<a class="dropdown-item active" href="#">Active link</a>
<a class="dropdown-item" href="#">Another link</a>
</div>
.disabled
ドロップダウンの項目に追加して、それらを disabled としてスタイルします。
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Regular link</a>
<a class="dropdown-item disabled" href="#">Disabled link</a>
<a class="dropdown-item" href="#">Another link</a>
</div>
ドロップダウン プラグインは、データ属性または JavaScript を介し.show
て、親リスト項目のクラスを切り替えることにより、非表示のコンテンツ (ドロップダウン メニュー) を切り替えます。このdata-toggle="dropdown"
属性は、アプリケーション レベルでドロップダウン メニューを閉じるために使用されるため、常に使用することをお勧めします。
タッチ対応デバイスでドロップダウンを開くと、要素の直接の子に空の ( $.noop
)ハンドラーが追加されます。この確かに醜いハックは、iOS のイベント デリゲーションの癖を回避するために必要です。そうしないと、ドロップダウンの外側のどこかをタップしても、ドロップダウンを閉じるコードがトリガーされなくなります。ドロップダウンが閉じられると、これらの追加の空のハンドラーは削除されます。mouseover
<body>
mouseover
data-toggle="dropdown"
リンクまたはボタンに追加して、ドロップダウンを切り替えます。
JavaScript を介してドロップダウンを呼び出します。
data-toggle="dropdown"
まだ必要
JavaScript を介してドロップダウンを呼び出すか、代わりに data-api を使用するかに関係なく、data-toggle="dropdown"
常にドロップダウンのトリガー要素に存在する必要があります。
オプションは、データ属性または JavaScript を介して渡すことができます。data-
データ属性の場合、オプション名をのようにに追加しますdata-offset=""
。
名前 | タイプ | デフォルト | 説明 |
---|---|---|---|
オフセット | 数 | 文字列 | 関数 | 0 | ターゲットに対するドロップダウンのオフセット。詳細については、Popper.js のオフセット ドキュメントを参照してください。 |
フリップ | ブール値 | 真実 | 参照要素が重なっている場合に、ドロップダウンが反転できるようにします。詳細については、Popper.js のフリップ ドキュメントを参照してください。 |
境界 | 文字列 | エレメント | 「スクロール親」 | ドロップダウン メニューのオーバーフロー制約境界。'viewport' 、'window' 、'scrollParent' 、または HTMLElement 参照 (JavaScript のみ)の値を受け入れます。詳細については、Popper.js のpreventOverflow docsを参照してください。 |
boundary
を 以外の値に設定する'scrollParent'
と、スタイルがコンテナにposition: static
適用されることに注意してください。.dropdown
方法 | 説明 |
---|---|
$().dropdown('toggle') |
特定のナビゲーション バーまたはタブ付きナビゲーションのドロップダウン メニューを切り替えます。 |
$().dropdown('update') |
要素のドロップダウンの位置を更新します。 |
$().dropdown('dispose') |
要素のドロップダウンを破棄します。 |
すべてのドロップダウン イベントは.dropdown-menu
の親要素で発生しrelatedTarget
、トグル アンカー要素を値とするプロパティがあります。
イベント | 説明 |
---|---|
show.bs.dropdown |
このイベントは、show インスタンス メソッドが呼び出されるとすぐに発生します。 |
shown.bs.dropdown |
このイベントは、ドロップダウンがユーザーに表示されるようになったときに発生します (CSS トランジションが完了するのを待ちます)。 |
hide.bs.dropdown |
このイベントは、hide インスタンス メソッドが呼び出されるとすぐに発生します。 |
hidden.bs.dropdown |
このイベントは、ドロップダウンがユーザーから非表示にされたときに発生します (CSS トランジションが完了するのを待ちます)。 |