Группы списков
Группы списков - это гибкий и мощный компонент для отображения серии контента. Измените и расширьте их для поддержки практически любого содержимого внутри.
Простой пример
Самая основная группа списков - это неупорядоченный список с элементами списка и соответствующими классами. Развивайте его, используя следующие параметры или собственный CSS, если необходимо.
- Элемент
- Второй элемент
- Третий элемент
- Четвертый элемент
- И пятый
<ul class="list-group">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
<li class="list-group-item">Четвертый элемент</li>
<li class="list-group-item">И пятый</li>
</ul>
Активные элементы
Добавьте .active
к .list-group-item
, чтобы указать текущий активный выбор.
- Активный элемент
- Второй элемент
- Третий элемент
- Четвертый элемент
- И пятый
<ul class="list-group">
<li class="list-group-item active" aria-current="true">Активный элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
<li class="list-group-item">Четвертый элемент</li>
<li class="list-group-item">И пятый</li>
</ul>
Отключенные элементы
Добавьте .disabled
к .list-group-item
, чтобы он показался отключенным. Обратите внимание, что для некоторых элементов с .disabled
также потребуется специальный JavaScript, чтобы полностью отключить их события щелчка (например, ссылки).
- Отключенный элемент
- Второй элемент
- Третий элемент
- Четвертый элемент
- И пятый
<ul class="list-group">
<li class="list-group-item disabled" aria-disabled="true">Отключенный элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
<li class="list-group-item">Четвертый элемент</li>
<li class="list-group-item">И пятый</li>
</ul>
Ссылки и кнопки
Используйте <a>
или <button>
, чтобы создать элементы группы actionable списка с наведением, отключенным и активным состояниями, добавив .list-group-item-action
. Мы разделяем эти псевдоклассы, чтобы группы списков, состоящие из неинтерактивных элементов (таких как <li>
или <div>
) не обеспечивали доступность щелчка или касания.
Обязательно не используйте здесь стандартные классы .btn
.
<div class="list-group">
<a href="#" class="list-group-item list-group-item-action active" aria-current="true">
Текущий элемент ссылка
</a>
<a href="#" class="list-group-item list-group-item-action">Второй элемент ссылка</a>
<a href="#" class="list-group-item list-group-item-action">Третий элемент ссылка</a>
<a href="#" class="list-group-item list-group-item-action">Четвертый элемент ссылка</a>
<a href="#" class="list-group-item list-group-item-action disabled" tabindex="-1" aria-disabled="true">Отключенный элемент ссылка</a>
</div>
С помощью <button>
Вы также можете использовать атрибут disabled
вместо класса .disabled
. К сожалению, <a>
не поддерживают атрибут.
<div class="list-group">
<button type="button" class="list-group-item list-group-item-action active" aria-current="true">
Текущая кнопка
</button>
<button type="button" class="list-group-item list-group-item-action">Второй элемент кнопка</button>
<button type="button" class="list-group-item list-group-item-action">Третий элемент кнопка</button>
<button type="button" class="list-group-item list-group-item-action">Четвертый элемент кнопка</button>
<button type="button" class="list-group-item list-group-item-action" disabled>Отключенный элемент кнопка</button>
</div>
Поток
Добавьте .list-group-flush
, чтобы удалить некоторые границы и закругленные углы для рендеринга элементов группы списков от края до края в родительском контейнере (например, карточки).
- Элемент
- Второй элемент
- Третий элемент
- Четвертый элемент
- И пятый
<ul class="list-group list-group-flush">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
<li class="list-group-item">Четвертый элемент</li>
<li class="list-group-item">И пятый</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
<ol class="list-group list-group-numbered">
<li class="list-group-item">Cras justo odio</li>
<li class="list-group-item">Cras justo odio</li>
<li class="list-group-item">Cras justo odio</li>
</ol>
Они также отлично работают с настраиваемым контентом.
-
ПодзаголовокCras justo odio
-
ПодзаголовокCras justo odio
-
ПодзаголовокCras justo odio
<ol class="list-group list-group-numbered">
<li class="list-group-item d-flex justify-content-between align-items-start">
<div class="ms-2 me-auto">
<div class="fw-bold">Подзаголовок</div>
Cras justo odio
</div>
<span class="badge bg-primary rounded-pill">14</span>
</li>
<li class="list-group-item d-flex justify-content-between align-items-start">
<div class="ms-2 me-auto">
<div class="fw-bold">Подзаголовок</div>
Cras justo odio
</div>
<span class="badge bg-primary rounded-pill">14</span>
</li>
<li class="list-group-item d-flex justify-content-between align-items-start">
<div class="ms-2 me-auto">
<div class="fw-bold">Подзаголовок</div>
Cras justo odio
</div>
<span class="badge bg-primary rounded-pill">14</span>
</li>
</ol>
По горизонтали
Добавьте .list-group-horizontal
, чтобы изменить расположение элементов группы списков с вертикального на горизонтальное во всех контрольных точках. В качестве альтернативы, выберите адаптивный вариант .list-group-horizontal-{sm|md|lg|xl|xxl}
, чтобы сделать группу списков горизонтальной, начиная с min-width
контрольной точки. В настоящее время группы горизонтального списка нельзя комбинировать с группами скрытого списка.
Совет: Хотите элементы группы списков одинаковой ширины в горизонтальном положении? Добавьте .flex-fill
к каждому элементу группы списка.
- Элемент
- Второй элемент
- Третий элемент
- Элемент
- Второй элемент
- Третий элемент
- Элемент
- Второй элемент
- Третий элемент
- Элемент
- Второй элемент
- Третий элемент
- Элемент
- Второй элемент
- Третий элемент
- Элемент
- Второй элемент
- Третий элемент
<ul class="list-group list-group-horizontal">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
<ul class="list-group list-group-horizontal-sm">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
<ul class="list-group list-group-horizontal-md">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
<ul class="list-group list-group-horizontal-lg">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
<ul class="list-group list-group-horizontal-xl">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
<ul class="list-group list-group-horizontal-xxl">
<li class="list-group-item">Элемент</li>
<li class="list-group-item">Второй элемент</li>
<li class="list-group-item">Третий элемент</li>
</ul>
Контекстные классы
Используйте контекстные классы для стилизации элементов списка с фоном и цветом с отслеживанием состояния.
- Простой элемент группы списка по умолчанию
- Простой primary элемент группы списка
- Простой secondary элемент группы списка
- Простой success элемент группы списка
- Простой danger элемент группы списка
- Простой warning элемент группы списка
- Простой info элемент группы списка
- Простой light элемент группы списка
- Простой dark элемент группы списка
<ul class="list-group">
<li class="list-group-item">Простой элемент группы списка по умолчанию</li>
<li class="list-group-item list-group-item-primary">Простой primary элемент группы списка</li>
<li class="list-group-item list-group-item-secondary">Простой secondary элемент группы списка</li>
<li class="list-group-item list-group-item-success">Простой success элемент группы списка</li>
<li class="list-group-item list-group-item-danger">Простой danger элемент группы списка</li>
<li class="list-group-item list-group-item-warning">Простой warning элемент группы списка</li>
<li class="list-group-item list-group-item-info">Простой info элемент группы списка</li>
<li class="list-group-item list-group-item-light">Простой light элемент группы списка</li>
<li class="list-group-item list-group-item-dark">Простой dark элемент группы списка</li>
</ul>
Контекстные классы также работают с .list-group-item-action
. Обратите внимание на добавление стилей наведения, которых не было в предыдущем примере. Также поддерживается состояние .active
; примените его, чтобы указать активный выбор в элементе группы контекстного списка.
<div class="list-group">
<a href="#" class="list-group-item list-group-item-action">Простой элемент группы списка по умолчанию</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-primary">Простой primary элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-secondary">Простой secondary элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-success">Простой success элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-danger">Простой danger элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-warning">Простой warning элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-info">Простой info элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-light">Простой light элемент группы списка</a>
<a href="#" class="list-group-item list-group-item-action list-group-item-dark">Простой dark элемент группы списка</a>
</div>
Передача смысла вспомогательным технологиям
Использование цвета для добавления смысла обеспечивает только визуальную индикацию, которая не будет передана пользователям вспомогательных технологий, таких как программы чтения с экрана. Убедитесь, что информация, обозначенная цветом, либо очевидна из самого содержимого (например, видимый текст), либо включена с помощью альтернативных средств, таких как дополнительный текст, скрытый с помощью класса .visually-hidden
.
Со значками
Добавьте значки к любому элементу группы списка, чтобы показать количество непрочитанных сообщений, активность и многое другое с помощью некоторых утилит.
- Элемент списка 14
- Второй элемент списка 2
- Третий элемент списка 1
<ul class="list-group">
<li class="list-group-item d-flex justify-content-between align-items-center">
Элемент списка
<span class="badge bg-primary rounded-pill">14</span>
</li>
<li class="list-group-item d-flex justify-content-between align-items-center">
Второй элемент списка
<span class="badge bg-primary rounded-pill">2</span>
</li>
<li class="list-group-item d-flex justify-content-between align-items-center">
Третий элемент списка
<span class="badge bg-primary rounded-pill">1</span>
</li>
</ul>
Пользовательский контент
Добавьте практически любой HTML-код, даже для групп связанных списков, подобных приведенной ниже, с помощью утилит flexbox.
Заголовок элемента группы списка
3 дня назадНекоторый заполнитель в абзаце.
И немного мелкого шрифта.Заголовок элемента группы списка
3 дня назадНекоторый заполнитель в абзаце.
И какой-то приглушенный мелкий шрифт.Заголовок элемента группы списка
3 дня назадНекоторый заполнитель в абзаце.
И какой-то приглушенный мелкий шрифт.<div class="list-group">
<a href="#" class="list-group-item list-group-item-action active" aria-current="true">
<div class="d-flex w-100 justify-content-between">
<h5 class="mb-1">Заголовок элемента группы списка</h5>
<small>3 дня назад</small>
</div>
<p class="mb-1">Некоторый заполнитель в абзаце.</p>
<small>И немного мелкого шрифта.</small>
</a>
<a href="#" class="list-group-item list-group-item-action">
<div class="d-flex w-100 justify-content-between">
<h5 class="mb-1">Заголовок элемента группы списка</h5>
<small class="text-muted">3 дня назад</small>
</div>
<p class="mb-1">Некоторый заполнитель в абзаце.</p>
<small class="text-muted">И какой-то приглушенный мелкий шрифт.</small>
</a>
<a href="#" class="list-group-item list-group-item-action">
<div class="d-flex w-100 justify-content-between">
<h5 class="mb-1">Заголовок элемента группы списка</h5>
<small class="text-muted">3 дня назад</small>
</div>
<p class="mb-1">Некоторый заполнитель в абзаце.</p>
<small class="text-muted">И какой-то приглушенный мелкий шрифт.</small>
</a>
</div>
Флажки и радио
Поместите флажки и радио Bootstrap в элементы группы списка и настройте их по мере необходимости. Вы можете использовать их без тегов <label>
, но не забудьте включить атрибут и значение aria-label
для доступности.
- Первый чекбокс
- Второй чекбокс
- Третий чекбокс
- Четвертый чекбокс
- Пятый чекбокс
<ul class="list-group">
<li class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="" aria-label="...">
Первый чекбокс
</li>
<li class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="" aria-label="...">
Второй чекбокс
</li>
<li class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="" aria-label="...">
Третий чекбокс
</li>
<li class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="" aria-label="...">
Четвертый чекбокс
</li>
<li class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="" aria-label="...">
Пятый чекбокс
</li>
</ul>
И если Вы хотите, чтобы <label>
в качестве .list-group-item
для больших областей попадания, Вы тоже могли это сделать.
<div class="list-group">
<label class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="">
Первый чекбокс
</label>
<label class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="">
Второй чекбокс
</label>
<label class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="">
Третий чекбокс
</label>
<label class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="">
Четвертый чекбокс
</label>
<label class="list-group-item">
<input class="form-check-input me-1" type="checkbox" value="">
Пятый чекбокс
</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, $value in $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
- чтобы расширить нашу группу списков для создания вкладок локального контента.
<div class="row">
<div class="col-4">
<div class="list-group" id="list-tab" role="tablist">
<a class="list-group-item list-group-item-action active" id="list-home-list" data-bs-toggle="list" href="#list-home" role="tab" aria-controls="list-home">Главная</a>
<a class="list-group-item list-group-item-action" id="list-profile-list" data-bs-toggle="list" href="#list-profile" role="tab" aria-controls="list-profile">Профиль</a>
<a class="list-group-item list-group-item-action" id="list-messages-list" data-bs-toggle="list" href="#list-messages" role="tab" aria-controls="list-messages">Сообщения</a>
<a class="list-group-item list-group-item-action" id="list-settings-list" data-bs-toggle="list" href="#list-settings" role="tab" aria-controls="list-settings">Настройки</a>
</div>
</div>
<div class="col-8">
<div class="tab-content" id="nav-tabContent">
<div class="tab-pane fade show active" id="list-home" role="tabpanel" aria-labelledby="list-home-list">...</div>
<div class="tab-pane fade" id="list-profile" role="tabpanel" aria-labelledby="list-profile-list">...</div>
<div class="tab-pane fade" id="list-messages" role="tabpanel" aria-labelledby="list-messages-list">...</div>
<div class="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
.
<div role="tabpanel">
<!-- Группа списка -->
<div class="list-group" id="myList" role="tablist">
<a class="list-group-item list-group-item-action active" data-bs-toggle="list" href="#home" role="tab">Главная</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#profile" role="tab">Профиль</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#messages" role="tab">Сообщения</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#settings" role="tab">Настройки</a>
</div>
<!-- Панели вкладок -->
<div div class="tab-content">
<div class="tab-pane active" id="home" role="tabpanel">...</div>
<div class="tab-pane" id="profile" role="tabpanel">...</div>
<div class="tab-pane" id="messages" role="tabpanel">...</div>
<div class="tab-pane" id="settings" role="tabpanel">...</div>
</div>
</div>
Через JavaScript
Включите элемент списка с вкладками через JavaScript (каждый элемент списка нужно активировать индивидуально):
var triggerTabList = [].slice.call(document.querySelectorAll('#myTab a'))
triggerTabList.forEach(function (triggerEl) {
var tabTrigger = new bootstrap.Tab(triggerEl)
triggerEl.addEventListener('click', function (event) {
event.preventDefault()
tabTrigger.show()
})
})
Вы можете активировать отдельный элемент списка несколькими способами:
var triggerEl = document.querySelector('#myTab a[href="#profile"]')
bootstrap.Tab.getInstance(triggerEl).show() // Выбрать вкладку по названию
var triggerFirstTabEl = document.querySelector('#myTab li:first-child a')
bootstrap.Tab.getInstance(triggerFirstTabEl).show() // Выберите первую вкладку
Эффект затухания
Чтобы панель вкладок постепенно увеличивалась, добавьте .fade
к каждому .tab-pane
. На первой панели вкладок также должен быть .show
, чтобы исходное содержимое было видимым.
<div class="tab-content">
<div class="tab-pane fade show active" id="home" role="tabpanel">...</div>
<div class="tab-pane fade" id="profile" role="tabpanel">...</div>
<div class="tab-pane fade" id="messages" role="tabpanel">...</div>
<div class="tab-pane fade" id="settings" role="tabpanel">...</div>
</div>
Методы
constructor
Активирует элемент элемента списка и контейнер содержимого. Вкладка должна иметь либо data-bs-target
либо href
, нацеленный на узел контейнера в DOM.
<div class="list-group" id="myList" role="tablist">
<a class="list-group-item list-group-item-action active" data-bs-toggle="list" href="#home" role="tab">Главная</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#profile" role="tab">Профиль</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#messages" role="tab">Сообщения</a>
<a class="list-group-item list-group-item-action" data-bs-toggle="list" href="#settings" role="tab">Настройки</a>
</div>
<div class="tab-content">
<div class="tab-pane active" id="home" role="tabpanel">...</div>
<div class="tab-pane" id="profile" role="tabpanel">...</div>
<div class="tab-pane" id="messages" role="tabpanel">...</div>
<div class="tab-pane" id="settings" role="tabpanel">...</div>
</div>
<script>
var firstTabEl = document.querySelector('#myTab a:last-child')
var firstTab = new bootstrap.Tab(firstTabEl)
firstTab.show()
</script>
show
Выбирает указанный элемент списка и показывает связанную с ним панель. Любой другой элемент списка, который был ранее выбран, становится невыделенным, а связанная с ним панель скрывается. Возврат к вызывающему абоненту до того, как панель вкладок будет отображена (например, до того, как произойдет событие shown.bs.tab
).
var someListItemEl = document.querySelector('#someListItem')
var tab = new bootstrap.Tab(someListItemEl)
tab.show()
dispose
Уничтожает вкладку элемента.
getInstance
Статический метод, позволяющий получить экземпляр вкладки, связанный с элементом DOM.
var triggerEl = document.querySelector('#trigger')
var tab = bootstrap.Tab.getInstance(triggerEl) // Возвращает экземпляр таба Bootstrap
getOrCreateInstance
Статический метод, который позволяет вам получить экземпляр вкладки, связанный с элементом DOM, или создать новый, если он не был инициализирован.
var triggerEl = document.querySelector('#trigger')
var tab = bootstrap.Tab.getOrCreateInstance(triggerEl) // Возвращает экземпляр таба Bootstrap
События
При отображении новой вкладки события запускаются в следующем порядке:
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 для таргетинга на предыдущую активную вкладку и новую активную вкладку соответственно. |
var tabElms = document.querySelectorAll('a[data-bs-toggle="list"]')
tabElms.forEach(function(tabElm) {
tabElm.addEventListener('shown.bs.tab', function (event) {
event.target // недавно активированная вкладка
event.relatedTarget // предыдущая активная вкладка
})
}