dropdowns.md 5.57 KB
Newer Older
Mark Otto's avatar
Mark Otto committed
1
2
3
---
layout: page
title: Dropdowns
4
group: components
Mark Otto's avatar
Mark Otto committed
5
6
---

7
Toggleable, contextual menu for displaying lists of links. Made interactive with the included dropdown JavaScript plugin.
Mark Otto's avatar
Mark Otto committed
8

Mark Otto's avatar
Mark Otto committed
9
10
11
12
13
## Contents

* Will be replaced with the ToC, excluding the "Contents" header
{:toc}

14
## Example
Mark Otto's avatar
Mark Otto committed
15
16
17
18
19

Wrap the dropdown's trigger and the dropdown menu within `.dropdown`, or another element that declares `position: relative;`. Then add the menu's HTML.

{% example html %}
<div class="dropdown">
Mark Otto's avatar
Mark Otto committed
20
  <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Mark Otto's avatar
Mark Otto committed
21
22
    Dropdown
  </button>
Mark Otto's avatar
Mark Otto committed
23
24
25
  <ul class="dropdown-menu" aria-labelledby="dropdownMenu1">
    <li>
      <a href="#">Action</a>
Mark Otto's avatar
Mark Otto committed
26
    </li>
Mark Otto's avatar
Mark Otto committed
27
28
    <li>
      <a href="#">Another action</a>
Mark Otto's avatar
Mark Otto committed
29
    </li>
Mark Otto's avatar
Mark Otto committed
30
31
    <li>
      <a href="#">Something else here</a>
Mark Otto's avatar
Mark Otto committed
32
33
34
35
36
    </li>
  </ul>
</div>
{% endexample %}

37
## Alignment
Mark Otto's avatar
Mark Otto committed
38
39
40

By default, a dropdown menu is automatically positioned 100% from the top and along the left side of its parent. Add `.dropdown-menu-right` to a `.dropdown-menu` to right align the dropdown menu.

41
42
43
44
45
{% callout warning %}
#### May require additional positioning

Dropdowns are automatically positioned via CSS within the normal flow of the document. This means dropdowns may be cropped by parents with certain `overflow` properties or appear out of bounds of the viewport. Address these issues on your own as they arise.
{% endcallout %}
Mark Otto's avatar
Mark Otto committed
46
47

{% highlight html %}
Mark Otto's avatar
Mark Otto committed
48
<ul class="dropdown-menu dropdown-menu-right" aria-labelledby="dLabel">
Mark Otto's avatar
Mark Otto committed
49
50
51
52
  ...
</ul>
{% endhighlight %}

53
## Menu headers
Mark Otto's avatar
Mark Otto committed
54
55
56
57

Add a header to label sections of actions in any dropdown menu.

{% example html %}
Mark Otto's avatar
Mark Otto committed
58
59
60
61
<ul class="dropdown-menu">
  <li class="dropdown-header">Dropdown header</li>
  <li>
    <a href="#">Action</a>
Mark Otto's avatar
Mark Otto committed
62
  </li>
Mark Otto's avatar
Mark Otto committed
63
64
  <li>
    <a href="#">Another action</a>
Mark Otto's avatar
Mark Otto committed
65
66
67
68
  </li>
</ul>
{% endexample %}

69
## Menu dividers
Mark Otto's avatar
Mark Otto committed
70
71
72
73

Separate groups of related menu items with a divider.

{% example html %}
Mark Otto's avatar
Mark Otto committed
74
75
76
<ul class="dropdown-menu">
  <li>
    <a href="#">Action</a>
Mark Otto's avatar
Mark Otto committed
77
  </li>
Mark Otto's avatar
Mark Otto committed
78
79
  <li>
    <a href="#">Another action</a>
Mark Otto's avatar
Mark Otto committed
80
  </li>
Mark Otto's avatar
Mark Otto committed
81
82
  <li>
    <a href="#">Something else here</a>
Mark Otto's avatar
Mark Otto committed
83
  </li>
Mark Otto's avatar
Mark Otto committed
84
85
86
  <li class="dropdown-divider"></li>
  <li>
    <a href="#">Separated link</a>
Mark Otto's avatar
Mark Otto committed
87
88
89
90
  </li>
</ul>
{% endexample %}

91
## Disabled menu items
Mark Otto's avatar
Mark Otto committed
92
93
94
95

Add `.disabled` to a `<li>` in the dropdown to disable the link.

{% example html %}
Mark Otto's avatar
Mark Otto committed
96
97
98
<ul class="dropdown-menu">
  <li>
    <a href="#">Regular link</a>
Mark Otto's avatar
Mark Otto committed
99
  </li>
Mark Otto's avatar
Mark Otto committed
100
101
  <li class="disabled">
    <a href="#">Disabled link</a>
Mark Otto's avatar
Mark Otto committed
102
  </li>
Mark Otto's avatar
Mark Otto committed
103
104
  <li>
    <a href="#">Another link</a>
Mark Otto's avatar
Mark Otto committed
105
106
107
  </li>
</ul>
{% endexample %}
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122

## Usage

Via data attributes or JavaScript, the dropdown plugin toggles hidden content (dropdown menus) by toggling the `.open` class on the parent list item.

On mobile devices, opening a dropdown adds a `.dropdown-backdrop` as a tap area for closing dropdown menus when tapping outside the menu, a requirement for proper iOS support. **This means that switching from an open dropdown menu to a different dropdown menu requires an extra tap on mobile.**

Note: The `data-toggle="dropdown"` attribute is relied on for closing dropdown menus at an application level, so it's a good idea to always use it.

### Via data attributes

Add `data-toggle="dropdown"` to a link or button to toggle a dropdown.

{% highlight html %}
<div class="dropdown">
Mark Otto's avatar
Mark Otto committed
123
  <button id="dLabel" type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
124
125
    Dropdown trigger
  </button>
Mark Otto's avatar
Mark Otto committed
126
  <ul class="dropdown-menu" aria-labelledby="dLabel">
127
128
129
130
131
132
133
134
135
    ...
  </ul>
</div>
{% endhighlight %}

To keep URLs intact with link buttons, use the `data-target` attribute instead of `href="#"`.

{% highlight html %}
<div class="dropdown">
Mark Otto's avatar
Mark Otto committed
136
  <a id="dLabel" data-target="#" href="http://example.com" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
137
138
139
    Dropdown trigger
  </a>

Mark Otto's avatar
Mark Otto committed
140
  <ul class="dropdown-menu" aria-labelledby="dLabel">
141
142
143
144
145
146
147
148
149
150
151
152
153
    ...
  </ul>
</div>
{% endhighlight %}

### Via JavaScript

Call the dropdowns via JavaScript:

{% highlight js %}
$('.dropdown-toggle').dropdown()
{% endhighlight %}

154
155
156
157
158
{% callout info %}
#### `data-toggle="dropdown"` still required

Regardless of whether you call your dropdown via JavaScript or instead use the data-api, `data-toggle="dropdown"` is always required to be present on the dropdown's trigger element.
{% endcallout %}
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207

### Options

*None.*

### Methods

#### $().dropdown('toggle')

Toggles the dropdown menu of a given navbar or tabbed navigation.

### Events

All dropdown events are fired at the `.dropdown-menu`'s parent element and have a `relatedTarget` property, whose value is the toggling anchor element.

<div class="table-responsive">
  <table class="table table-bordered table-striped">
    <thead>
      <tr>
        <th style="width: 150px;">Event Type</th>
        <th>Description</th>
      </tr>
    </thead>
    <tbody>
      <tr>
        <td>show.bs.dropdown</td>
        <td>This event fires immediately when the show instance method is called.</td>
      </tr>
      <tr>
        <td>shown.bs.dropdown</td>
        <td>This event is fired when the dropdown has been made visible to the user (will wait for CSS transitions, to complete).</td>
      </tr>
      <tr>
        <td>hide.bs.dropdown</td>
        <td>This event is fired immediately when the hide instance method has been called.</td>
      </tr>
      <tr>
        <td>hidden.bs.dropdown</td>
        <td>This event is fired when the dropdown has finished being hidden from the user (will wait for CSS transitions, to complete).</td>
      </tr>
    </tbody>
  </table>
</div>

{% highlight js %}
$('#myDropdown').on('show.bs.dropdown', function () {
  // do something…
})
{% endhighlight %}