You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

dropdowns.html 11 KiB

3 vuotta sitten
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <div class="bs-docs-section">
  2. <h1 id="dropdowns" class="page-header">Dropdowns <small>dropdown.js</small></h1>
  3. <h2 id="dropdowns-examples">Examples</h2>
  4. <p>Add dropdown menus to nearly anything with this simple plugin, including the navbar, tabs, and pills.</p>
  5. <h3>Within a navbar</h3>
  6. <div class="bs-example">
  7. <nav id="navbar-example" class="navbar navbar-default navbar-static" role="navigation">
  8. <div class="container-fluid">
  9. <div class="navbar-header">
  10. <button class="navbar-toggle collapsed" type="button" data-toggle="collapse" data-target=".bs-example-js-navbar-collapse">
  11. <span class="sr-only">Toggle navigation</span>
  12. <span class="icon-bar"></span>
  13. <span class="icon-bar"></span>
  14. <span class="icon-bar"></span>
  15. </button>
  16. <a class="navbar-brand" href="#">Project Name</a>
  17. </div>
  18. <div class="collapse navbar-collapse bs-example-js-navbar-collapse">
  19. <ul class="nav navbar-nav">
  20. <li class="dropdown">
  21. <a id="drop1" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  22. Dropdown
  23. <span class="caret"></span>
  24. </a>
  25. <ul class="dropdown-menu" role="menu" aria-labelledby="drop1">
  26. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  27. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  28. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  29. <li role="presentation" class="divider"></li>
  30. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  31. </ul>
  32. </li>
  33. <li class="dropdown">
  34. <a id="drop2" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  35. Dropdown
  36. <span class="caret"></span>
  37. </a>
  38. <ul class="dropdown-menu" role="menu" aria-labelledby="drop2">
  39. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  40. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  41. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  42. <li role="presentation" class="divider"></li>
  43. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  44. </ul>
  45. </li>
  46. </ul>
  47. <ul class="nav navbar-nav navbar-right">
  48. <li id="fat-menu" class="dropdown">
  49. <a id="drop3" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  50. Dropdown
  51. <span class="caret"></span>
  52. </a>
  53. <ul class="dropdown-menu" role="menu" aria-labelledby="drop3">
  54. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  55. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  56. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  57. <li role="presentation" class="divider"></li>
  58. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  59. </ul>
  60. </li>
  61. </ul>
  62. </div><!-- /.nav-collapse -->
  63. </div><!-- /.container-fluid -->
  64. </nav> <!-- /navbar-example -->
  65. </div> <!-- /example -->
  66. <h3>Within pills</h3>
  67. <div class="bs-example">
  68. <ul class="nav nav-pills" role="tablist">
  69. <li role="presentation" class="active"><a href="#">Regular link</a></li>
  70. <li role="presentation" class="dropdown">
  71. <a id="drop4" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  72. Dropdown
  73. <span class="caret"></span>
  74. </a>
  75. <ul id="menu1" class="dropdown-menu" role="menu" aria-labelledby="drop4">
  76. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  77. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  78. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  79. <li role="presentation" class="divider"></li>
  80. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  81. </ul>
  82. </li>
  83. <li role="presentation" class="dropdown">
  84. <a id="drop5" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  85. Dropdown
  86. <span class="caret"></span>
  87. </a>
  88. <ul id="menu2" class="dropdown-menu" role="menu" aria-labelledby="drop5">
  89. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  90. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  91. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  92. <li role="presentation" class="divider"></li>
  93. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  94. </ul>
  95. </li>
  96. <li role="presentation" class="dropdown">
  97. <a id="drop6" href="#" class="dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  98. Dropdown
  99. <span class="caret"></span>
  100. </a>
  101. <ul id="menu3" class="dropdown-menu" role="menu" aria-labelledby="drop6">
  102. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Action</a></li>
  103. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Another action</a></li>
  104. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Something else here</a></li>
  105. <li role="presentation" class="divider"></li>
  106. <li role="presentation"><a role="menuitem" tabindex="-1" href="https://twitter.com/fat">Separated link</a></li>
  107. </ul>
  108. </li>
  109. </ul> <!-- /pills -->
  110. </div> <!-- /example -->
  111. <h2 id="dropdowns-usage">Usage</h2>
  112. <p>Via data attributes or JavaScript, the dropdown plugin toggles hidden content (dropdown menus) by toggling the <code>.open</code> class on the parent list item.</p>
  113. <p>On mobile devices, opening a dropdown adds a <code>.dropdown-backdrop</code> as a tap area for closing dropdown menus when tapping outside the menu, a requirement for proper iOS support. <strong class="text-danger">This means that switching from an open dropdown menu to a different dropdown menu requires an extra tap on mobile.</strong></p>
  114. <p>Note: The <code>data-toggle="dropdown"</code> attribute is relied on for closing dropdown menus at an application level, so it's a good idea to always use it.</p>
  115. <h3>Via data attributes</h3>
  116. <p>Add <code>data-toggle="dropdown"</code> to a link or button to toggle a dropdown.</p>
  117. {% highlight html %}
  118. <div class="dropdown">
  119. <button id="dLabel" type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  120. Dropdown trigger
  121. <span class="caret"></span>
  122. </button>
  123. <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">
  124. ...
  125. </ul>
  126. </div>
  127. {% endhighlight %}
  128. <p>To keep URLs intact with link buttons, use the <code>data-target</code> attribute instead of <code>href="#"</code>.</p>
  129. {% highlight html %}
  130. <div class="dropdown">
  131. <a id="dLabel" data-target="#" href="http://example.com" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  132. Dropdown trigger
  133. <span class="caret"></span>
  134. </a>
  135. <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">
  136. ...
  137. </ul>
  138. </div>
  139. {% endhighlight %}
  140. <h3>Via JavaScript</h3>
  141. <p>Call the dropdowns via JavaScript:</p>
  142. {% highlight js %}
  143. $('.dropdown-toggle').dropdown()
  144. {% endhighlight %}
  145. <div class="bs-callout bs-callout-info">
  146. <h4><code>data-toggle="dropdown"</code> still required</h4>
  147. <p>Regardless of whether you call your dropdown via JavaScript or instead use the data-api, <code>data-toggle="dropdown"</code> is always required to be present on the dropdown's trigger element.</p>
  148. </div>
  149. <h3>Options</h3>
  150. <p><em>None</em></p>
  151. <h3>Methods</h3>
  152. <h4>$().dropdown('toggle')</h4>
  153. <p>Toggles the dropdown menu of a given navbar or tabbed navigation.</p>
  154. <h3>Events</h3>
  155. <p>All dropdown events are fired at the <code>.dropdown-menu</code>'s parent element.</p>
  156. <div class="table-responsive">
  157. <table class="table table-bordered table-striped">
  158. <thead>
  159. <tr>
  160. <th style="width: 150px;">Event Type</th>
  161. <th>Description</th>
  162. </tr>
  163. </thead>
  164. <tbody>
  165. <tr>
  166. <td>show.bs.dropdown</td>
  167. <td>This event fires immediately when the show instance method is called. The toggling anchor element is available as the <code>relatedTarget</code> property of the event.</td>
  168. </tr>
  169. <tr>
  170. <td>shown.bs.dropdown</td>
  171. <td>This event is fired when the dropdown has been made visible to the user (will wait for CSS transitions, to complete). The toggling anchor element is available as the <code>relatedTarget</code> property of the event.</td>
  172. </tr>
  173. <tr>
  174. <td>hide.bs.dropdown</td>
  175. <td>This event is fired immediately when the hide instance method has been called. The toggling anchor element is available as the <code>relatedTarget</code> property of the event.</td>
  176. </tr>
  177. <tr>
  178. <td>hidden.bs.dropdown</td>
  179. <td>This event is fired when the dropdown has finished being hidden from the user (will wait for CSS transitions, to complete). The toggling anchor element is available as the <code>relatedTarget</code> property of the event.</td>
  180. </tr>
  181. </tbody>
  182. </table>
  183. </div><!-- ./bs-table-responsive -->
  184. {% highlight js %}
  185. $('#myDropdown').on('show.bs.dropdown', function () {
  186. // do something…
  187. })
  188. {% endhighlight %}
  189. </div>