Перемикайте контекстні накладення для відображення списків посилань тощо за допомогою розкривного плагіна Bootstrap.
Огляд
Випадаючі меню – це контекстні накладки, які можна перемикати, для відображення списків посилань тощо. Вони стають інтерактивними за допомогою плагіна JavaScript, що випадає, Bootstrap. Вони перемикаються клацанням, а не наведенням; це навмисне дизайнерське рішення .
Випадаючі списки побудовані на сторонній бібліотеці Popper.js , яка забезпечує динамічне позиціонування та визначення вікна перегляду. Обов’язково включіть popper.min.js перед JavaScript Bootstrap або використовуйте bootstrap.bundle.min.js/ bootstrap.bundle.js, який містить Popper.js. Popper.js не використовується для розміщення розкривних списків у навігаційних панелях, хоча динамічне позиціонування не потрібне.
Якщо ви створюєте наш JavaScript із вихідного коду, для цього потрібноutil.js .
Доступність
Стандарт WAI ARIA визначає фактичний role="menu"віджет , але це стосується програмних меню, які запускають дії або функції. Меню ARIA можуть містити лише пункти меню, пункти меню прапорців, елементи меню перемикачів, групи перемикачів і підменю.
Випадаючі меню Bootstrap, з іншого боку, створені як загальні та застосовні до різноманітних ситуацій і структур розмітки. Наприклад, можна створити розкривні списки, які містять додаткові введення та елементи керування формою, такі як поля пошуку або форми входу. З цієї причини Bootstrap не очікує (і не додає автоматично) жодного з атрибутів roleі , необхідних для справжніх меню ARIA . Автори повинні будуть самі включити ці конкретніші атрибути.aria-
Однак Bootstrap додає вбудовану підтримку для більшості стандартних взаємодій із меню клавіатури, наприклад, можливість переміщатися між окремими .dropdown-itemелементами за допомогою клавіш курсору та закривати меню за допомогою ESCклавіші.
Приклади
Загорніть перемикач спадного меню (вашу кнопку чи посилання) і спадне меню всередину .dropdownабо інший елемент, який оголошує position: relative;. Випадаючі списки можна запускати з <a>або <button>елементів, щоб краще відповідати вашим потенційним потребам.
Одна кнопка
Будь-яку одиницю .btnможна перетворити на перемикач спадного меню, змінивши розмітку. Ось як ви можете використовувати їх для роботи з <button>елементами:
Подібним чином створюйте спадні списки розділених кнопок із практично тією самою розміткою, що й розкривні списки з однією кнопкою, але з додаванням .dropdown-toggle-splitдля правильного інтервалу навколо розкривного меню.
Ми використовуємо цей додатковий клас, щоб зменшити горизонталь paddingз обох боків каретки на 25% і видалити те margin-left, що додається для звичайних розкривних кнопок. Ці додаткові зміни зберігають каретку в центрі розділеної кнопки та забезпечують відповідніший розмір області влучення поряд із основною кнопкою.
Історично вміст спадного меню мав бути посиланнями, але це вже не стосується версії 4. Тепер ви можете додатково використовувати <button>елементи у своїх спадних меню замість просто <a>s.
Ви також можете створювати неінтерактивні спадні елементи за допомогою .dropdown-item-text. Не соромтеся додавати додаткові стилі за допомогою спеціальних CSS або текстових утиліт.
За замовчуванням спадне меню автоматично розташовується на 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 не використовується в панелях навігацій.
Зміст меню
Заголовки
Додайте заголовок, щоб позначити розділи дій у будь-якому спадному меню.
Розмістіть будь-який текст довільної форми в спадному меню з текстом і використовуйте утиліти для створення інтервалів . Зауважте, що вам, ймовірно, знадобляться додаткові стилі розміру, щоб обмежити ширину меню.
Деякі приклади тексту, який вільно переливається в спадному меню.
І це ще приклад тексту.
Форми
Розмістіть форму в розкривному меню або перетворіть її в спадне меню та скористайтеся утилітами полів або відступів, щоб надати їй необхідний негативний простір.
За допомогою атрибутів даних або JavaScript плагін спадного меню перемикає прихований вміст (випадаючі меню), перемикаючи .showклас у батьківському елементі списку. Атрибут data-toggle="dropdown"використовується для закриття спадних меню на рівні програми, тому доцільно використовувати його завжди.
На сенсорних пристроях відкриття спадного меню додає порожні ( $.noop) mouseoverобробники до безпосередніх дочірніх <body>елементів елемента. Цей, безсумнівно, потворний хак необхідний для вирішення проблеми з делегуванням подій iOS , яка в іншому випадку перешкоджала б запуску коду, який закриває спадне меню, будь-де за межами спадного меню. Після закриття спадного меню ці додаткові пусті mouseoverобробники видаляються.
Через атрибути даних
Додайте data-toggle="dropdown"до посилання або кнопку, щоб увімкнути спадне меню.
Через JavaScript
Виклик спадних меню через JavaScript:
data-toggle="dropdown"все ще потрібно
Незалежно від того, викликаєте ви розкривне меню за допомогою JavaScript чи натомість використовуєте data-api, data-toggle="dropdown"завжди має бути присутнім у тригерному елементі розкривного меню.
Опції
Параметри можна передати через атрибути даних або JavaScript. Для атрибутів даних додайте назву опції до data-, як у data-offset="".
Ім'я
Тип
За замовчуванням
опис
зсув
номер | рядок | функція
0
Зсув спадного списку відносно його цілі. Для отримання додаткової інформації зверніться до офс��тної документації Popper.js .
фліп
логічний
правда
Дозволити спадному меню перевертатися у разі перекриття опорного елемента. Для отримання додаткової інформації зверніться до перевернутих документів Popper.js .
межа
рядок | елемент
'scrollParent'
Межа обмеження переповнення спадного меню. Приймає значення 'viewport', 'window', 'scrollParent'або посилання HTMLElement (тільки для JavaScript). Для отримання додаткової інформації зверніться до документів PreventOverflow Popper.js .
посилання
рядок | елемент
'перемикач'
Посилальний елемент спадного меню. Приймає значення 'toggle', 'parent'або посилання HTMLElement. Для отримання додаткової інформації зверніться до документів referenceObject Popper.js .
дисплей
рядок
"динамічний"
За замовчуванням ми використовуємо Popper.js для динамічного позиціонування. Вимкніть це за допомогою static.
Зауважте, що якщо 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).