Sourceドロップダウン
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>
どちらの要素でも動作させる方法は次のとおりです。
そして<a>
要素で:
最良の部分は、ボタンのバリアントでもこれを実行できることです。
同様に、単一ボタン ドロップダウンと実質的に同じマークアップを使用して分割ボタン ドロップダウンを作成しますが.dropdown-toggle-split
、ドロップダウン キャレットの周囲に適切なスペースを追加します。
この追加のクラスを使用してpadding
、キャレットの両側の水平方向を 25%縮小し、margin-left
通常のボタン ドロップダウンに追加された を削除します。これらの追加の変更により、キャレットが分割ボタンの中央に配置され、メイン ボタンの横により適切なサイズのヒット領域が提供されます。
サイジング
ボタン ドロップダウンは、デフォルトのドロップダウン ボタンやスプリット ドロップダウン ボタンなど、あらゆるサイズのボタンで機能します。
方向
ドロップアップ
.dropup
親要素に追加して、要素の上のドロップダウン メニューをトリガーします。
ドロップライト
.dropright
親要素に追加して、要素の右側にあるドロップダウン メニューをトリガーします。
ドロップレフト
.dropleft
親要素に追加して、要素の左側にあるドロップダウン メニューをトリガーします。
従来、ドロップダウン メニューのコンテンツはリンクでなければなりませんでしたが、v4 ではそうではなくなりました。<button>
オプションで、sだけでなく、ドロップダウンで要素を使用できるようになりまし<a>
た。
を使用して非インタラクティブなドロップダウン アイテムを作成することもできます.dropdown-item-text
。カスタム CSS またはテキスト ユーティリティを使用して、自由にスタイルを設定してください。
アクティブ
.active
ドロップダウンのアイテムに追加して、それらをアクティブとしてスタイルします。
無効
.disabled
ドロップダウンの項目に追加して、それらを disabled としてスタイルします。
デフォルトでは、ドロップダウン メニューは親の左側に沿って上から 100% の位置に自動的に配置されます。ドロップダウン メニューを右揃え.dropdown-menu-right
にするには、aに追加します。.dropdown-menu
注意喚起!ドロップダウンは、Popper.js のおかげで配置されます (ナビゲーション バーに含まれている場合を除く)。
レスポンシブ アライメント
レスポンシブ アライメントを使用する場合は、属性を追加して動的配置を無効にしdata-display="static"
、レスポンシブ バリエーション クラスを使用します。
ドロップダウン メニューを特定のブレークポイント以上に揃えるには、 を追加します.dropdown-menu{-sm|-md|-lg|-xl}-right
。
ドロップダウン メニューを特定のブレークポイント以上で左揃えにするには、 と を追加.dropdown-menu-right
し.dropdown-menu{-sm|-md|-lg|-xl}-left
ます。
data-display="static"
ナビゲーション バーでは Popper.js が使用されないため、ナビゲーション バーのドロップダウン ボタンに属性を追加する必要がないことに注意してください。
ヘッダーを追加して、ドロップダウン メニューのアクションのセクションにラベルを付けます。
仕切り
関連するメニュー項目のグループを仕切りで分けます。
文章
テキスト付きのドロップダウン メニュー内に自由形式のテキストを配置し、スペーシング ユーティリティを使用します。メニューの幅を制限するには、追加のサイズ変更スタイルが必要になる可能性があることに注意してください。
ドロップダウン メニュー内にフォームを配置するか、フォームをドロップダウン メニューにして、マージンまたはパディング ユーティリティを使用して、必要な負のスペースをフォームに与えます。
ドロップダウン オプション
data-offset
またはを使用data-reference
して、ドロップダウンの場所を変更します。
使用法
ドロップダウン プラグインは、データ属性または JavaScript を介し.show
て、親リスト項目のクラスを切り替えることにより、非表示のコンテンツ (ドロップダウン メニュー) を切り替えます。このdata-toggle="dropdown"
属性は、アプリケーション レベルでドロップダウン メニューを閉じるために使用されるため、常に使用することをお勧めします。
タッチ対応デバイスでドロップダウンを開くと、要素の直接の子に空の ( $.noop
)ハンドラーが追加されます。この確かに醜いハックは、iOS のイベント デリゲーションの癖を回避するために必要です。そうしないと、ドロップダウンの外側のどこかをタップしても、ドロップダウンを閉じるコードがトリガーされなくなります。ドロップダウンが閉じられると、これらの追加の空のハンドラーは削除されます。mouseover
<body>
mouseover
データ属性経由
data-toggle="dropdown"
リンクまたはボタンに追加して、ドロップダウンを切り替えます。
JavaScript 経由
JavaScript を介してドロップダウンを呼び出します。
data-toggle="dropdown"
まだ必要
JavaScript を介してドロップダウンを呼び出すか、代わりに data-api を使用するかに関係なく、data-toggle="dropdown"
常にドロップダウンのトリガー要素に存在する必要があります。
オプション
オプションは、データ属性または JavaScript を介して渡すことができます。data-
データ属性の場合、オプション名をのようにに追加しますdata-offset=""
。
名前 |
タイプ |
デフォルト |
説明 |
オフセット |
数 | 文字列 | 関数 |
0 |
ターゲットに対するドロップダウンのオフセット。 オフセットを決定するために関数が使用される場合、その関数はオフセット データを含むオブジェクトを最初の引数として呼び出されます。関数は、同じ構造を持つオブジェクトを返さなければなりません。トリガー要素の DOM ノードは、2 番目の引数として渡されます。 詳細については、Popper.js のオフセット ドキュメントを参照してください。 |
フリップ |
ブール値 |
真実 |
参照要素が重なっている場合に、ドロップダウンが反転できるようにします。詳細については、Popper.js のフリップ ドキュメントを参照してください。 |
境界 |
文字列 | エレメント |
「スクロール親」 |
ドロップダウン メニューのオーバーフロー制約境界。'viewport' 、'window' 、'scrollParent' 、または HTMLElement 参照 (JavaScript のみ)の値を受け入れます。詳細については、Popper.js のpreventOverflow docsを参照してください。 |
参照 |
文字列 | エレメント |
'トグル' |
ドロップダウン メニューの参照要素。'toggle' 、'parent' 、または HTMLElement 参照の値を受け入れます。詳細については、Popper.js のreferenceObject docsを参照してください。 |
画面 |
ストリング |
'動的' |
デフォルトでは、動的ポジショニングに Popper.js を使用します。でこれを無効にしstatic ます。 |
popperConfig |
null | null | 物体 |
ヌル |
Bootstrap のデフォルトの Popper.js 構成を変更するには、Popper.js の構成を参照してください。 |
boundary
を 以外の値に設定する'scrollParent'
と、スタイルがコンテナにposition: static
適用されることに注意してください。.dropdown
メソッド
方法 |
説明 |
$().dropdown('toggle') |
特定のナビゲーション バーまたはタブ付きナビゲーションのドロップダウン メニューを切り替えます。 |
$().dropdown('show') |
特定のナビゲーション バーまたはタブ付きナビゲーションのドロップダウン メニューを表示します。 |
$().dropdown('hide') |
特定のナビゲーション バーまたはタブ付きナビゲーションのドロップダウン メニューを非表示にします。 |
$().dropdown('update') |
要素のドロップダウンの位置を更新します。 |
$().dropdown('dispose') |
要素のドロップダウンを破棄します。 |
イベント
すべてのドロップダウン イベントは.dropdown-menu
の親要素で発生しrelatedTarget
、トグル アンカー要素を値とするプロパティがあります。イベントhide.bs.dropdown
には、クリック イベントのイベント オブジェクトを含むプロパティがあります (元のイベント タイプが の場合のみ)。hidden.bs.dropdown
clickEvent
click
イベント |
説明 |
show.bs.dropdown |
このイベントは、show インスタンス メソッドが呼び出されるとすぐに発生します。 |
shown.bs.dropdown |
このイベントは、ドロップダウンがユーザーに表示されるようになったときに発生します (CSS トランジションが完了するのを待ちます)。 |
hide.bs.dropdown |
このイベントは、hide インスタンス メソッドが呼び出されるとすぐに発生します。 |
hidden.bs.dropdown |
このイベントは、ドロップダウンがユーザーから非表示にされたときに発生します (CSS トランジションが完了するのを待ちます)。 |