Alterne sobreposições contextuais para exibir listas de links e muito mais com o plug-in suspenso Bootstrap.
Visão geral
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 projeto 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.jsque 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 .
Acessibilidade
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 rolee 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-itemelementos individuais usando as teclas do cursor e fechar o menu com a ESCtecla.
Exemplos
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.
Botão único
Qualquer single .btnpode 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:
Da mesma forma, crie listas suspensas de botão dividido com praticamente a mesma marcação das listas suspensas de botão único, mas com a adição de .dropdown-toggle-splitespaçamento adequado ao redor do cursor suspenso.
Usamos essa classe extra para reduzir a horizontal paddingem ambos os lados do cursor em 25% e remover o margin-leftque é 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.
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.
Você também pode criar itens suspensos não interativos com .dropdown-item-text. Sinta-se à vontade para estilizar ainda mais com CSS personalizado ou utilitários de texto.
Por padrão, um menu suspenso é posicionado automaticamente 100% na parte superior e no lado esquerdo de seu pai. Adicionar .dropdown-menu-righta .dropdown-menupara 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).
Alinhamento responsivo
Se você quiser usar o alinhamento responsivo, desative o posicionamento dinâmico adicionando o data-display="static"atributo e use as classes de variação responsiva.
Para alinhar à direita o menu suspenso com o ponto de interrupção fornecido ou maior, adicione .dropdown-menu{-sm|-md|-lg|-xl}-right.
Para alinhar à esquerda o menu suspenso com o ponto de interrupção fornecido ou maior, adicione .dropdown-menu-righte .dropdown-menu{-sm|-md|-lg|-xl}-left.
Observe que você não precisa adicionar um data-display="static"atributo aos botões suspensos nas navbars, pois o Popper.js não é usado nas navbars.
Conteúdo do cardápio
Cabeçalhos
Adicione um cabeçalho para rotular seções de ações em qualquer menu suspenso.
Coloque qualquer texto de forma livre em um menu suspenso com texto e use utilitários de espaçamento . Observe que você provavelmente precisará de estilos de dimensionamento adicionais para restringir a largura do menu.
Alguns exemplos de texto que fluem livremente no menu suspenso.
E este é mais um texto de exemplo.
Formulários
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.
Por meio de atributos de dados ou JavaScript, o plug-in suspenso alterna o conteúdo oculto (menus suspensos) alternando a .showclasse 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) mouseoveraos 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 mouseovermanipuladores vazios adicionais são removidos.
Por atributos de dados
Adicione data-toggle="dropdown"a um link ou botão para alternar uma lista suspensa.
Por JavaScript
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.
Opções
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.
Quando uma função é usada para determinar o deslocamento, ela é chamada com um objeto contendo os dados do deslocamento como seu primeiro argumento. A função deve retornar um objeto com a mesma estrutura. O nó DOM do elemento acionador é passado como o segundo argumento.
Para obter mais informações, consulte os documentos de deslocamento do Popper.js .
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 .
referência
seqüência | elemento
'alternar'
Elemento de referência do menu suspenso. Aceita os valores de 'toggle', 'parent'ou uma referência HTMLElement. Para obter mais informações, consulte os documentos referenceObject do Popper.js .
exibição
corda
'dinâmico'
Por padrão, usamos Popper.js para posicionamento dinâmico. Desative isso com static.
Observe que quando boundaryé definido com qualquer valor diferente de 'scrollParent', o estilo position: staticé aplicado ao .dropdowncontêiner.
Métodos
Método
Descrição
$().dropdown('toggle')
Alterna o menu suspenso de uma determinada barra de navegação ou navegação com guias.
$().dropdown('show')
Mostra o menu suspenso de uma determinada barra de navegação ou navegação com guias.
$().dropdown('hide')
Oculta 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.
Eventos
Todos os eventos suspensos são disparados no .dropdown-menuelemento pai do 's e possuem uma relatedTargetpropriedade, cujo valor é o elemento âncora de alternância. hide.bs.dropdowne hidden.bs.dropdowneventos têm uma clickEventpropriedade (somente quando o tipo de evento original é click) que contém um objeto de evento para o evento de clique.
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).