Группа списков
Группы списков - это гибкий и мощный компонент для отображения контента. Изменяйте и расширяйте их для поддержки практически любого содержимого.
Базовый пример
Самая простая группа списков – это неупорядоченный список из элементов нужных классов. Создавайте на этой основе свою разметку и свой CSS, если нужно.
- An item
- A second item
- A third item
- A fourth item
- And a fifth one
<ulclass="list-group"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li><liclass="list-group-item">A fourth item</li><liclass="list-group-item">And a fifth one</li></ul>Активные элементы
Добавьте в .list-group-item класс .active для обозначения текущего активного выбора.
- An active item
- A second item
- A third item
- A fourth item
- And a fifth one
<ulclass="list-group"><liclass="list-group-item active"aria-current="true">An active item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li><liclass="list-group-item">A fourth item</li><liclass="list-group-item">And a fifth one</li></ul>Неактивные элементы
Добавьте класс .disabled к элементу класса .list-group-item для придания последнему вида «неактивного». Заметьте, что некоторые элементы класса .disabled также потребуют JavaScript для полной деактивации их событий клика (например, ссылки).
- A disabled item
- A second item
- A third item
- A fourth item
- And a fifth one
<ulclass="list-group"><liclass="list-group-item disabled"aria-disabled="true">A disabled item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li><liclass="list-group-item">A fourth item</li><liclass="list-group-item">And a fifth one</li></ul>Ссылки и кнопки
Используйте <a> или <button> для создания элементов группы списка с возможностью возложить на них некое действие – с наличием «ховера» (наведения), неактивных и активных состояний – добавляя в них .list-group-item-action. Мы разделяем эти псевдоклассы для уверенности в том, что группы списков, созданные из не-интерактивных элементов (как <li> или <div>), не будут позволять поддержку касания или клика.
Удостоверьтесь, что не используете стандартные классы .btn в описанном выше случае.
<divclass="list-group"><ahref="#"class="list-group-item list-group-item-action active"aria-current="true"> The current link item </a><ahref="#"class="list-group-item list-group-item-action">A second link item</a><ahref="#"class="list-group-item list-group-item-action">A third link item</a><ahref="#"class="list-group-item list-group-item-action">A fourth link item</a><ahref="#"class="list-group-item list-group-item-action disabled"tabindex="-1"aria-disabled="true">A disabled link item</a></div>В <button> вы можете также использовать атрибут disabled вместо класса .disabled. К сожалению, <a> не поддерживают отключенный атрибут.
<divclass="list-group"><buttontype="button"class="list-group-item list-group-item-action active"aria-current="true"> The current button </button><buttontype="button"class="list-group-item list-group-item-action">A second item</button><buttontype="button"class="list-group-item list-group-item-action">A third button item</button><buttontype="button"class="list-group-item list-group-item-action">A fourth button item</button><buttontype="button"class="list-group-item list-group-item-action"disabled>A disabled button item</button></div>Заполнение
Добавьте класс .list-group-flush чтобы удалить некоторые границы и закругленные углы, а также чтобы отображать элементы группы списка от края до края в родительском контейнере (например, в карточках).
- An item
- A second item
- A third item
- A fourth item
- And a fifth one
<ulclass="list-group list-group-flush"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li><liclass="list-group-item">A fourth item</li><liclass="list-group-item">And a fifth one</li></ul>Пронумерованный
Добавьте класс модификатора .list-group-numbered (и, при необходимости, используйте элемент <ol>), чтобы выбрать элементы группы нумерованных списков. Числа генерируются с помощью CSS (в отличие от стиля браузера по умолчанию для <ol>) для лучшего размещения внутри элементов группы списков и для лучшей настройки.
Числа генерируются с помощью counter-reset в <ol>, а затем стилируются и помещаются с помощью псевдоэлемента ::before в <li> с counter-increment и content.
- Cras justo odio
- Cras justo odio
- Cras justo odio
<olclass="list-group list-group-numbered"><liclass="list-group-item">Cras justo odio</li><liclass="list-group-item">Cras justo odio</li><liclass="list-group-item">Cras justo odio</li></ol>Они также отлично работают с настраиваемым контентом.
- 14ПодзаголовокCras justo odio
- 14ПодзаголовокCras justo odio
- 14ПодзаголовокCras justo odio
<olclass="list-group list-group-numbered"><liclass="list-group-item d-flex justify-content-between align-items-start"><divclass="ms-2 me-auto"><divclass="fw-bold">Подзаголовок</div> Cras justo odio </div><spanclass="badge bg-primary rounded-pill">14</span></li><liclass="list-group-item d-flex justify-content-between align-items-start"><divclass="ms-2 me-auto"><divclass="fw-bold">Подзаголовок</div> Cras justo odio </div><spanclass="badge bg-primary rounded-pill">14</span></li><liclass="list-group-item d-flex justify-content-between align-items-start"><divclass="ms-2 me-auto"><divclass="fw-bold">Подзаголовок</div> Cras justo odio </div><spanclass="badge bg-primary rounded-pill">14</span></li></ol>Горизонтальный
Добавьте .list-group-horizontal, чтобы изменить расположение элементов группы списков с вертикального на горизонтальное для всех точек останова. Или же выберите адаптивный вариант .list-group-horizontal-{sm|md|lg|xl|xxl}, чтобы сделать группу списков горизонтальной, начиная с min-width точки останова. В настоящее время горизонтальные группы списков не могут быть объединены с группами списков заполнения.
Совет: Хотите, чтобы элементы списка равной ширины были горизонтальными? Добавьте .flex-fill к каждому элементу группы списков.
- An item
- A second item
- A third item
- An item
- A second item
- A third item
- An item
- A second item
- A third item
- An item
- A second item
- A third item
- An item
- A second item
- A third item
- An item
- A second item
- A third item
<ulclass="list-group list-group-horizontal"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul><ulclass="list-group list-group-horizontal-sm"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul><ulclass="list-group list-group-horizontal-md"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul><ulclass="list-group list-group-horizontal-lg"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul><ulclass="list-group list-group-horizontal-xl"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul><ulclass="list-group list-group-horizontal-xxl"><liclass="list-group-item">An item</li><liclass="list-group-item">A second item</li><liclass="list-group-item">A third item</li></ul>Контекстные классы
Используйте их для стилизации элементов списка и придания им оттенков смысла с помощью цвета и фона.
- A simple default list group item
- A simple primary list group item
- A simple secondary list group item
- A simple success list group item
- A simple danger list group item
- A simple warning list group item
- A simple info list group item
- A simple light list group item
- A simple dark list group item
<ulclass="list-group"><liclass="list-group-item">A simple default list group item</li><liclass="list-group-item list-group-item-primary">A simple primary list group item</li><liclass="list-group-item list-group-item-secondary">A simple secondary list group item</li><liclass="list-group-item list-group-item-success">A simple success list group item</li><liclass="list-group-item list-group-item-danger">A simple danger list group item</li><liclass="list-group-item list-group-item-warning">A simple warning list group item</li><liclass="list-group-item list-group-item-info">A simple info list group item</li><liclass="list-group-item list-group-item-light">A simple light list group item</li><liclass="list-group-item list-group-item-dark">A simple dark list group item</li></ul>Контекстные классы также работают с классом .list-group-item-action. Отметим наличие дополнения стилей «ховера» (наведения), которых нет в предыдущем примере. Активное состояние .active также поддерживается, применяйте его для индикации активного выбора в элементе контекстуальной группы списка.
<divclass="list-group"><ahref="#"class="list-group-item list-group-item-action">A simple default list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-primary">A simple primary list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-secondary">A simple secondary list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-success">A simple success list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-danger">A simple danger list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-warning">A simple warning list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-info">A simple info list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-light">A simple light list group item</a><ahref="#"class="list-group-item list-group-item-action list-group-item-dark">A simple dark list group item</a></div>Использование вспомогательных технологий
Использование цвета как дополнительного инструмента информативности доступно только в визуальной сфере, что ограничивает пользователей вспомогательных технологий, например, программ для чтения текста с экрана. Удостоверьтесь, что информация обозначенная цветом, также доступна и из самого контента (например, видимый текст) или содержится в альтернативных средствах – таких как дополнительный скрытый в классе .visually-hidden текст.
Со значками
Добавляйте значки в любой элемент группы списков для показа счетчиков, активности и т.п. с помощью Flex утилит.
- A list item 14
- A second list item 2
- A third list item 1
<ulclass="list-group"><liclass="list-group-item d-flex justify-content-between align-items-center"> A list item <spanclass="badge bg-primary rounded-pill">14</span></li><liclass="list-group-item d-flex justify-content-between align-items-center"> A second list item <spanclass="badge bg-primary rounded-pill">2</span></li><liclass="list-group-item d-flex justify-content-between align-items-center"> A third list item <spanclass="badge bg-primary rounded-pill">1</span></li></ul>Пользовательское содержимое
Добавьте почти любой код HTML с помощью утилит флексбокса, даже для групп списков со ссылками, как в примере ниже.
<divclass="list-group"><ahref="#"class="list-group-item list-group-item-action active"aria-current="true"><divclass="d-flex w-100 justify-content-between"><h5class="mb-1">List group item heading</h5><small>3 days ago</small></div><pclass="mb-1">Some placeholder content in a paragraph.</p><small>And some small print.</small></a><ahref="#"class="list-group-item list-group-item-action"><divclass="d-flex w-100 justify-content-between"><h5class="mb-1">List group item heading</h5><smallclass="text-muted">3 days ago</small></div><pclass="mb-1">Some placeholder content in a paragraph.</p><smallclass="text-muted">And some muted small print.</small></a><ahref="#"class="list-group-item list-group-item-action"><divclass="d-flex w-100 justify-content-between"><h5class="mb-1">List group item heading</h5><smallclass="text-muted">3 days ago</small></div><pclass="mb-1">Some placeholder content in a paragraph.</p><smallclass="text-muted">And some muted small print.</small></a></div>Чекбоксы и радиокнопки
Поместите чекбоксы и радиокнопки в элементы группы списков и настройте их по мере необходимости. Вы можете использовать их без тегов <label>, но не забудьте включить атрибут и значение aria-label для доступности.
- First checkbox
- Second checkbox
- Third checkbox
- Fourth checkbox
- Fifth checkbox
<ulclass="list-group"><liclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""aria-label="..."> First checkbox </li><liclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""aria-label="..."> Second checkbox </li><liclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""aria-label="..."> Third checkbox </li><liclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""aria-label="..."> Fourth checkbox </li><liclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""aria-label="..."> Fifth checkbox </li></ul>Также можете использовать <label> в качестве элемента .list-group-item
<divclass="list-group"><labelclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""> First checkbox </label><labelclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""> Second checkbox </label><labelclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""> Third checkbox </label><labelclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""> Fourth checkbox </label><labelclass="list-group-item"><inputclass="form-check-input me-1"type="checkbox"value=""> Fifth checkbox </label></div>Sass
Переменные
$list-group-color:$gray-900;$list-group-bg:$white;$list-group-border-color:rgba($black,.125);$list-group-border-width:$border-width;$list-group-border-radius:$border-radius;$list-group-item-padding-y:$spacer*.5;$list-group-item-padding-x:$spacer;$list-group-item-bg-scale:-80%;$list-group-item-color-scale:40%;$list-group-hover-bg:$gray-100;$list-group-active-color:$component-active-color;$list-group-active-bg:$component-active-bg;$list-group-active-border-color:$list-group-active-bg;$list-group-disabled-color:$gray-600;$list-group-disabled-bg:$list-group-bg;$list-group-action-color:$gray-700;$list-group-action-hover-color:$list-group-action-color;$list-group-action-active-color:$body-color;$list-group-action-active-bg:$gray-200;Миксины
Используется в сочетании с $theme-colors для генерации классов контекстных вариантов для .list-group-item.
@mixin list-group-item-variant($state,$background,$color){.list-group-item-#{$state}{color:$color;background-color:$background;&.list-group-item-action{&:hover,&:focus{color:$color;background-color:shade-color($background,10%);}&.active{color:$white;background-color:$color;border-color:$color;}}}}Цикл
Цикл, который генерирует классы модификаторов с помощью миксина list-group-item-variant().
// List group contextual variants
//
// Add modifier classes to change text and background color on individual items.
// Organizationally, this must come after the `:hover` states.
@each$state,$valuein$theme-colors{$list-group-variant-bg:shift-color($value,$list-group-item-bg-scale);$list-group-variant-color:shift-color($value,$list-group-item-color-scale);@if(contrast-ratio($list-group-variant-bg,$list-group-variant-color)<$min-contrast-ratio){$list-group-variant-color:mix($value,color-contrast($list-group-variant-bg),abs($list-group-item-color-scale));}@include list-group-item-variant($state,$list-group-variant-bg,$list-group-variant-color);}Поведение JavaScript
Используйте плагин вкладок JavaScript – включите его индивидуальный или через скомпилированный файл bootstrap.js - для расширения группы списков и создания вкладок с содержимым.
<divclass="row"><divclass="col-4"><divclass="list-group"id="list-tab"role="tablist"><aclass="list-group-item list-group-item-action active"id="list-home-list"data-bs-toggle="list"href="#list-home"role="tab"aria-controls="home">Home</a><aclass="list-group-item list-group-item-action"id="list-profile-list"data-bs-toggle="list"href="#list-profile"role="tab"aria-controls="profile">Profile</a><aclass="list-group-item list-group-item-action"id="list-messages-list"data-bs-toggle="list"href="#list-messages"role="tab"aria-controls="messages">Messages</a><aclass="list-group-item list-group-item-action"id="list-settings-list"data-bs-toggle="list"href="#list-settings"role="tab"aria-controls="settings">Settings</a></div></div><divclass="col-8"><divclass="tab-content"id="nav-tabContent"><divclass="tab-pane fade show active"id="list-home"role="tabpanel"aria-labelledby="list-home-list">...</div><divclass="tab-pane fade"id="list-profile"role="tabpanel"aria-labelledby="list-profile-list">...</div><divclass="tab-pane fade"id="list-messages"role="tabpanel"aria-labelledby="list-messages-list">...</div><divclass="tab-pane fade"id="list-settings"role="tabpanel"aria-labelledby="list-settings-list">...</div></div></div></div>Используя атрибуты
Вы можете активировать навигацию в группе списка без JavaScript, а просто добавив data-bs-toggle="list" в элемент. Используйте эти атрибуты в .list-group-item.
<divrole="tabpanel"><!-- List group --><divclass="list-group"id="myList"role="tablist"><aclass="list-group-item list-group-item-action active"data-bs-toggle="list"href="#home"role="tab">Home</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#profile"role="tab">Profile</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#messages"role="tab">Messages</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#settings"role="tab">Settings</a></div><!-- Tab panes --><divclass="tab-content"><divclass="tab-pane active"id="home"role="tabpanel">...</div><divclass="tab-pane"id="profile"role="tabpanel">...</div><divclass="tab-pane"id="messages"role="tabpanel">...</div><divclass="tab-pane"id="settings"role="tabpanel">...</div></div></div>Через JavaScript
Включите элемент списка с вкладками через JavaScript (каждый элемент списка надо активировать отдельно):
vartriggerTabList=[].slice.call(document.querySelectorAll('#myTab a'))triggerTabList.forEach(function(triggerEl){vartabTrigger=newbootstrap.Tab(triggerEl)triggerEl.addEventListener('click',function(event){event.preventDefault()tabTrigger.show()})})Вы можете активировать отдельный элемент списка несколькими способами:
vartriggerEl=document.querySelector('#myTab a[href="#profile"]')bootstrap.Tab.getInstance(triggerEl).show()// Select tab by name
vartriggerFirstTabEl=document.querySelector('#myTab li:first-child a')bootstrap.Tab.getInstance(triggerFirstTabEl).show()// Select first tab
Эффект угасания
Чтобы заставить панель вкладок постепенно появиться, добавьте класс .fade в каждый элемент класса .tab-pane. На первой панели вкладки также должно быть выставлено значение .show, чтобы сделать начальное содержимое видимым.
<divclass="tab-content"><divclass="tab-pane fade show active"id="home"role="tabpanel">...</div><divclass="tab-pane fade"id="profile"role="tabpanel">...</div><divclass="tab-pane fade"id="messages"role="tabpanel">...</div><divclass="tab-pane fade"id="settings"role="tabpanel">...</div></div>Методы
constructor
Активирует элемент списка и контейнер содержимого. Вкладка должна иметь или data-bs-target, или href «нацеленный» на «узел контейнера» в DOM.
<divclass="list-group"id="myList"role="tablist"><aclass="list-group-item list-group-item-action active"data-bs-toggle="list"href="#home"role="tab">Home</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#profile"role="tab">Profile</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#messages"role="tab">Messages</a><aclass="list-group-item list-group-item-action"data-bs-toggle="list"href="#settings"role="tab">Settings</a></div><divclass="tab-content"><divclass="tab-pane active"id="home"role="tabpanel">...</div><divclass="tab-pane"id="profile"role="tabpanel">...</div><divclass="tab-pane"id="messages"role="tabpanel">...</div><divclass="tab-pane"id="settings"role="tabpanel">...</div></div><script>varfirstTabEl=document.querySelector('#myTab a:last-child')varfirstTab=newbootstrap.Tab(firstTabEl)firstTab.show()</script>show
Выбирает данный элемент списка и показывает связанные с ним панели. Любой другой элемент списка, который был ранее выбран, становится «невыбранным», а связанные с ним панели – скрытыми. Возвращается к функции-вызову до того, как показалась панель вкладки (например, до события shown.bs.tab).
varsomeListItemEl=document.querySelector('#someListItem')vartab=newbootstrap.Tab(someListItemEl)tab.show()dispose
Уничтожает вкладку TAB элемента.
getInstance
Статический метод, позволяющий получить экземпляр вкладки, связанный с элементом DOM.
vartriggerEl=document.querySelector('#trigger')vartab=bootstrap.Tab.getInstance(triggerEl)// Returns a Bootstrap tab instance
События
При показе новой вкладки события запускаются в таком порядке:
hide.bs.tab(на текущей активной вкладке)show.bs.tab(на вкладке, которая вот-вот покажется)hidden.bs.tab(на предыдущей активной вкладке, такое же, как для событияhide.bs.tab)shown.bs.tab(на вкладке, только что ставшей активной и только что ставшей показанной, такое же, как для событияshow.bs.tab)
Если ни одна вкладка еще не была активной, события hide.bs.tab и hidden.bs.tab не произойдут.
| Тип события | Описание |
|---|---|
show.bs.tab | Используйте события event.target и event.relatedTarget для «нацеливания» на соответственно на активную и предыдущую активную (если она доступна) вкладки. |
shown.bs.tab | Это событие наступает при показе вкладки, после того, как она показана. Используйте события event.target и event.relatedTarget для «нацеливания» соответственно на активную и предыдущую активную (если она доступна) вкладки. |
hide.bs.tab | Это событие наступает, когда вот-вот покажется новая вкладка (и предыдущая, т.о., вот-вот скроется). Используйте события event.target и event.relatedTarget для «нацеливания» соответственно на активную текущую вкладку и ту, которая вот-вот откроется. |
hidden.bs.tab | Это событие наступает, когда показана новая вкладка (и предыдущая активная, т.о., скрылась). Используйте события event.target и event.relatedTarget для «нацеливания» соответственно на предыдущую активную и новую активную вкладки. |
vartabElms=document.querySelectorAll('a[data-bs-toggle="list"]')tabElms.forEach(function(tabElm){tabElm.addEventListener('shown.bs.tab',function(event){event.target// недавно активированная вкладка
event.relatedTarget// предыдущая активная вкладка
})}