Listas suspensas
Alterne sobreposições contextuais para exibir listas de links e muito mais com o plug-in suspenso Bootstrap.
As listas suspensas são sobreposições contextuais alternáveis para exibir listas de links e muito mais. Eles são feitos interativos com o plug-in de JavaScript suspenso Bootstrap incluído. Eles são alternados clicando, não passando o mouse; esta é uma decisão de design intencional.
As listas suspensas são criadas em uma biblioteca de terceiros, Popper.js , que fornece posicionamento dinâmico e detecção de janela de visualização. Certifique-se de incluir popper.min.js antes do JavaScript do Bootstrap ou use bootstrap.bundle.min.js
/ bootstrap.bundle.js
que contém Popper.js. Popper.js não é usado para posicionar dropdowns em navbars, embora o posicionamento dinâmico não seja necessário.
Se você estiver construindo nosso JavaScript a partir da fonte, ele requerutil.js
.
O padrão WAI ARIA define um role="menu"
widget real , mas isso é específico para menus semelhantes a aplicativos que acionam ações ou funções. Os menus ARIA podem conter apenas itens de menu, itens de menu de caixa de seleção, itens de menu de botão de opção, grupos de botões de opção e submenus.
As listas suspensas do Bootstrap, por outro lado, são projetadas para serem genéricas e aplicáveis a uma variedade de situações e estruturas de marcação. Por exemplo, é possível criar dropdowns que contenham entradas e controles de formulário adicionais, como campos de pesquisa ou formulários de login. Por esse motivo, o Bootstrap não espera (nem adiciona automaticamente) nenhum dos atributos role
e necessários para menus ARIA verdadeiros. Os autores terão que incluir esses atributos mais específicos.aria-
No entanto, o Bootstrap adiciona suporte interno para a maioria das interações de menu de teclado padrão, como a capacidade de mover .dropdown-item
elementos individuais usando as teclas do cursor e fechar o menu com a ESCtecla.
Enrole a alternância do menu suspenso (seu botão ou link) e o menu suspenso dentro de .dropdown
, ou outro elemento que declare position: relative;
. As listas suspensas podem ser acionadas a partir de <a>
elementos <button>
para melhor atender às suas necessidades potenciais.
Qualquer single .btn
pode ser transformado em uma alternância suspensa com algumas alterações de marcação. Veja como você pode colocá-los para funcionar com qualquer um dos <button>
elementos:
<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>
E com <a>
elementos:
<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>
A melhor parte é que você também pode fazer isso com qualquer variante de botão:
Da mesma forma, crie listas suspensas de botão dividido com praticamente a mesma marcação que as listas suspensas de botão único, mas com a adição de .dropdown-toggle-split
espaçamento adequado ao redor do cursor suspenso.
Usamos essa classe extra para reduzir a horizontal padding
em ambos os lados do cursor em 25% e remover o margin-left
que é adicionado para menus suspensos de botões regulares. Essas alterações extras mantêm o cursor centralizado no botão de divisão e fornecem uma área de acerto de tamanho mais apropriado ao lado do botão principal.
Os menus suspensos de botão funcionam com botões de todos os tamanhos, incluindo botões suspensos padrão e divididos.
Acione menus suspensos acima dos elementos adicionando .dropup
ao elemento pai.
Acione menus suspensos à direita dos elementos adicionando .dropright
ao elemento pai.
Acione menus suspensos à esquerda dos elementos adicionando .dropleft
ao elemento pai.
Historicamente, o conteúdo do menu suspenso tinha que ser links, mas esse não é mais o caso da v4. Agora, opcionalmente, você pode usar <button>
elementos em suas listas suspensas em vez de apenas <a>
s.
<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>
Por padrão, um menu suspenso é posicionado automaticamente 100% na parte superior e no lado esquerdo de seu pai. Adicionar .dropdown-menu-right
a .dropdown-menu
para alinhar à direita o menu suspenso.
Atenção! Os dropdowns são posicionados graças ao Popper.js (exceto quando estão contidos em uma barra de navegação).
<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>
Adicione um cabeçalho para rotular seções de ações em qualquer menu suspenso.
<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>
Grupos separados de itens de menu relacionados com um divisor.
<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>
Coloque um formulário em um menu suspenso ou transforme-o em um menu suspenso e use utilitários de margem ou preenchimento para fornecer o espaço negativo necessário.
<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>
Adicione .active
itens na lista suspensa para estilizá- los como ativos .
<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>
Adicione .disabled
itens na lista suspensa para estilizá- los como desabilitados .
<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>
Por meio de atributos de dados ou JavaScript, o plug-in suspenso alterna o conteúdo oculto (menus suspensos) alternando a .show
classe no item da lista pai. O data-toggle="dropdown"
atributo é usado para fechar menus suspensos em um nível de aplicativo, portanto, é uma boa ideia sempre usá-lo.
Em dispositivos habilitados para toque, abrir uma lista suspensa adiciona manipuladores vazios ( $.noop
) mouseover
aos filhos imediatos do <body>
elemento. Esse hack reconhecidamente feio é necessário para contornar uma peculiaridade na delegação de eventos do iOS , que de outra forma impediria que um toque em qualquer lugar fora do menu suspenso acionasse o código que fecha o menu suspenso. Depois que a lista suspensa é fechada, esses mouseover
manipuladores vazios adicionais são removidos.
Adicione data-toggle="dropdown"
a um link ou botão para alternar uma lista suspensa.
Chame as listas suspensas via JavaScript:
data-toggle="dropdown"
ainda é necessário
Independentemente de você chamar sua lista suspensa via JavaScript ou usar a API de dados, data-toggle="dropdown"
é sempre necessário estar presente no elemento de gatilho da lista suspensa.
As opções podem ser passadas por meio de atributos de dados ou JavaScript. Para atributos de dados, anexe o nome da opção a data-
, como em data-offset=""
.
Nome | Modelo | Predefinição | Descrição |
---|---|---|---|
Deslocamento | número | seqüência | função | 0 | Deslocamento da lista suspensa em relação ao seu destino. Para obter mais informações, consulte os documentos de deslocamento do Popper.js . |
virar | boleano | verdadeiro | Permitir que o menu suspenso gire em caso de sobreposição no elemento de referência. Para obter mais informações, consulte os flip docs do Popper.js . |
fronteira | seqüência | elemento | 'scrollParent' | Limite de restrição de estouro do menu suspenso. Aceita os valores de 'viewport' , 'window' , 'scrollParent' ou uma referência HTMLElement (somente JavaScript). Para obter mais informações, consulte os documentos preventOverflow do Popper.js . |
Observe que quando boundary
é definido com qualquer valor diferente de 'scrollParent'
, o estilo position: static
é aplicado ao .dropdown
contêiner.
Método | Descrição |
---|---|
$().dropdown('toggle') |
Alterna o menu suspenso de uma determinada barra de navegação ou navegação com guias. |
$().dropdown('update') |
Atualiza a posição da lista suspensa de um elemento. |
$().dropdown('dispose') |
Destrói a lista suspensa de um elemento. |
Todos os eventos suspensos são disparados no .dropdown-menu
elemento pai do 's e possuem uma relatedTarget
propriedade, cujo valor é o elemento âncora de alternância.
Evento | Descrição |
---|---|
show.bs.dropdown |
Este evento é acionado imediatamente quando o método de instância show é chamado. |
shown.bs.dropdown |
Este evento é acionado quando a lista suspensa se torna visível para o usuário (aguardará as transições CSS para serem concluídas). |
hide.bs.dropdown |
Este evento é disparado imediatamente quando o método de instância hide é chamado. |
hidden.bs.dropdown |
Este evento é acionado quando a lista suspensa termina de ser ocultada do usuário (aguardará a conclusão das transições CSS). |