Bootstrap Button group (группа кнопок)

Bootstrap 5 предоставляет возможность создания групп кнопок, которые позволяют объединять несколько кнопок вместе для более удобного управления ими. Группы кнопок могут быть использованы для создания переключателей, радиокнопок, чекбоксов, выпадающих списков и других элементов управления.

Что такое группа кнопок?

Группа кнопок представляет собой набор кнопок, объединенных в рамках одного контейнера. Они могут быть расположены горизонтально или вертикально и обычно используются для предоставления выбора пользователю.

Преимущества использования группы кнопок

Использование группы кнопок имеет ряд преимуществ:

  • Ясность интерфейса: Группа кнопок позволяет пользователю ясно видеть доступные варианты действий.
  • Легкость взаимодействия: Пользователь может легко выбрать нужный вариант, так как кнопки находятся близко друг к другу.
  • Эстетический вид: Группа кнопок позволяет создавать эстетически привлекательные интерфейсы.

Примеры использования групп кнопок

Базовый пример

Давайте рассмотрим простой пример группы кнопок. Обернем серию кнопок с помощью класса .btn в элемент .btn-group.

<div class="btn-group" role="group" aria-label="Basic example">
  <button type="button" class="btn btn-primary">Слева</button>
  <button type="button" class="btn btn-primary">Посередине</button>
  <button type="button" class="btn btn-primary">Справа</button>
</div>
Результат:

В этом примере мы создали группу из трех кнопок с классом .btn-primary. Для групп кнопок требуется атрибут role и явная метка, чтобы вспомогательные технологии, такие как программы чтения с экрана, могли идентифицировать кнопки как сгруппированные и сообщать о них. Мы использовали role="group" для группы кнопок и добавили атрибут aria-label для пометки.

Эти классы также можно добавлять в группы ссылок в качестве альтернативы .nav навигационным компонентам.

<div class="btn-group">
  <a href="#" class="btn btn-primary active" aria-current="page">Активная ссылка</a>
  <a href="#" class="btn btn-primary">Ссылка</a>
  <a href="#" class="btn btn-primary">Ссылка</a>
</div>

Смешанные стили

Вы также можете создавать группы кнопок с разными стилями. Например:

<div class="btn-group" role="group" aria-label="Basic mixed styles example">
  <button type="button" class="btn btn-danger">Слева</button>
  <button type="button" class="btn btn-warning">Посередине</button>
  <button type="button" class="btn btn-success">Справа</button>
</div>
Результат:

Общие стили

<div class="btn-group" role="group" aria-label="Basic outlined example">
  <button type="button" class="btn btn-outline-primary">Слева</button>
  <button type="button" class="btn btn-outline-primary">Посередине</button>
  <button type="button" class="btn btn-outline-primary">Справа</button>
</div>
Результат:

Группы флажков и переключателей

Группы кнопок также могут использоваться для объединения флажков и радио-кнопок. Вот примеры:

Флажки

<div class="btn-group" role="group" aria-label="Basic checkbox toggle button group">
  <input type="checkbox" class="btn-check" id="btncheck1" autocomplete="off">
  <label class="btn btn-outline-primary" for="btncheck1">Флажок 1</label>

  <input type="checkbox" class="btn-check" id="btncheck2" autocomplete="off">
  <label class="btn btn-outline-primary" for="btncheck2">Флажок 2</label>

  <input type="checkbox" class="btn-check" id="btncheck3" autocomplete="off">
  <label class="btn btn-outline-primary" for="btncheck3">Флажок 3</label>
</div>
Результат:

Радио-кнопки

<div class="btn-group" role="group" aria-label="Basic radio toggle button group">
  <input type="radio" class="btn-check" name="btnradio" id="btnradio1" autocomplete="off" checked>
  <label class="btn btn-outline-primary" for="btnradio1">Radio 1</label>

  <input type="radio" class="btn-check" name="btnradio" id="btnradio2" autocomplete="off">
  <label class="btn btn-outline-primary" for="btnradio2">Radio 2</label>

  <input type="radio" class="btn-check" name="btnradio" id="btnradio3" autocomplete="off">
  <label class="btn btn-outline-primary" for="btnradio3">Radio 3</label>
</div>
Результат:

Панель инструментов кнопок

Объединяйте наборы групп кнопок в панели инструментов кнопок для получения более сложных компонентов. Используйте служебные классы по мере необходимости для размещения групп, кнопок и многого другого.

<div class="btn-toolbar" role="toolbar" aria-label="Toolbar with button groups">
  <div class="btn-group me-2" role="group" aria-label="First group">
    <button type="button" class="btn btn-primary">1</button>
    <button type="button" class="btn btn-primary">2</button>
    <button type="button" class="btn btn-primary">3</button>
    <button type="button" class="btn btn-primary">4</button>
  </div>
  <div class="btn-group me-2" role="group" aria-label="Second group">
    <button type="button" class="btn btn-secondary">5</button>
    <button type="button" class="btn btn-secondary">6</button>
    <button type="button" class="btn btn-secondary">7</button>
  </div>
  <div class="btn-group" role="group" aria-label="Third group">
    <button type="button" class="btn btn-info">8</button>
  </div>
</div>

Не стесняйтесь смешивать группы ввода с группами кнопок на ваших панелях инструментов. Как и в примере выше, вам, вероятно, понадобятся некоторые утилиты для правильного размещения объектов.

<div class="btn-toolbar mb-3" role="toolbar" aria-label="Toolbar with button groups">
  <div class="btn-group me-2" role="group" aria-label="First group">
    <button type="button" class="btn btn-outline-secondary">1</button>
    <button type="button" class="btn btn-outline-secondary">2</button>
    <button type="button" class="btn btn-outline-secondary">3</button>
    <button type="button" class="btn btn-outline-secondary">4</button>
  </div>
  <div class="input-group">
    <div class="input-group-text" id="btnGroupAddon">@</div>
    <input type="text" class="form-control" placeholder="Input group example" aria-label="Input group example" aria-describedby="btnGroupAddon">
  </div>
</div>

<div class="btn-toolbar justify-content-between" role="toolbar" aria-label="Toolbar with button groups">
  <div class="btn-group" role="group" aria-label="First group">
    <button type="button" class="btn btn-outline-secondary">1</button>
    <button type="button" class="btn btn-outline-secondary">2</button>
    <button type="button" class="btn btn-outline-secondary">3</button>
    <button type="button" class="btn btn-outline-secondary">4</button>
  </div>
  <div class="input-group">
    <div class="input-group-text" id="btnGroupAddon2">@</div>
    <input type="text" class="form-control" placeholder="Input group example" aria-label="Input group example" aria-describedby="btnGroupAddon2">
  </div>
</div>
Результат:

Определение размера

Вместо применения классов определения размера кнопок к каждой кнопке в группе, просто добавьте .btn-group-* к каждой .btn-group, включая каждую из них при вложении нескольких групп.

<div class="btn-group btn-group-lg" role="group" aria-label="Large button group">
  <button type="button" class="btn btn-outline-primary">Слева</button>
  <button type="button" class="btn btn-outline-primary">Посередине</button>
  <button type="button" class="btn btn-outline-primary">Справа</button>
</div>
<br>
<div class="btn-group" role="group" aria-label="Default button group">
  <button type="button" class="btn btn-outline-primary">Слева</button>
  <button type="button" class="btn btn-outline-primary">Посередине</button>
  <button type="button" class="btn btn-outline-primary">Справа</button>
</div>
<br>
<div class="btn-group btn-group-sm" role="group" aria-label="Small button group">
  <button type="button" class="btn btn-outline-primary">Слева</button>
  <button type="button" class="btn btn-outline-primary">Посередине</button>
  <button type="button" class="btn btn-outline-primary">Справа</button>
</div>
Результат:


Вложенность

Поместите .btn-group внутри другого .btn-group, если вы хотите, чтобы выпадающие меню были смешаны с серией кнопок.

<div class="btn-group" role="group" aria-label="Button group with nested dropdown">
  <button type="button" class="btn btn-primary">1</button>
  <button type="button" class="btn btn-primary">2</button>

  <div class="btn-group" role="group">
    <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
      Выпадающий список
    </button>
    <ul class="dropdown-menu">
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
    </ul>
  </div>
</div>
Результат:

Изменение по вертикали

Сделайте так, чтобы набор кнопок отображался вертикально, а не горизонтально. Раскрывающиеся списки разделенных кнопок здесь не поддерживаются.

<div class="btn-group-vertical" role="group" aria-label="Vertical button group">
  <button type="button" class="btn btn-primary">Кнопка</button>
  <button type="button" class="btn btn-primary">Кнопка</button>
  <button type="button" class="btn btn-primary">Кнопка</button>
  <button type="button" class="btn btn-primary">Кнопка</button>
</div>
Результат:
<div class="btn-group-vertical" role="group" aria-label="Vertical button group">
  <button type="button" class="btn btn-primary">Button</button>
  <button type="button" class="btn btn-primary">Button</button>
  <div class="btn-group" role="group">
    <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
      Dropdown
    </button>
    <ul class="dropdown-menu">
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
    </ul>
  </div>
  <div class="btn-group dropstart" role="group">
    <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
      Dropdown
    </button>
    <ul class="dropdown-menu">
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
    </ul>
  </div>
  <div class="btn-group dropend" role="group">
    <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
      Dropdown
    </button>
    <ul class="dropdown-menu">
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
    </ul>
  </div>
  <div class="btn-group dropup" role="group">
    <button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
      Dropdown
    </button>
    <ul class="dropdown-menu">
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
      <li><a class="dropdown-item" href="#">Dropdown link</a></li>
    </ul>
  </div>
</div>
Результат:
<div class="btn-group-vertical" role="group" aria-label="Vertical radio toggle button group">
  <input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio1" autocomplete="off" checked>
  <label class="btn btn-outline-danger" for="vbtn-radio1">Radio 1</label>
  <input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio2" autocomplete="off">
  <label class="btn btn-outline-danger" for="vbtn-radio2">Radio 2</label>
  <input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio3" autocomplete="off">
  <label class="btn btn-outline-danger" for="vbtn-radio3">Radio 3</label>
</div>
Результат:

FAQ (ответы на часто задаваемые вопросы)

Группа кнопок — это инструмент, который позволяет организовать несколько кнопок в интерфейсе веб-приложения. Она улучшает навигацию и помогает сгруппировать кнопки для более удобного использования.
Группы кнопок в Bootstrap 5 предоставляют удобный способ организации нескольких кнопок на веб-странице, улучшают пользовательский опыт и делают веб-интерфейс более удобным для пользователей.
Для создания группы кнопок используйте элемент <div> с классом .btn-group. Внутри него разместите кнопки с соответствующими классами (например, .btn-primary).
Горизонтальная группа кнопок отображает кнопки горизонтально, одну рядом с другой, в то время как вертикальная группа кнопок отображает кнопки вертикально, одну под другой.
Для настройки стилей кнопок в Bootstrap 5 можно использовать встроенные классы, а также создавать собственные стили с помощью CSS, переопределяя стандартные стили фреймворка.

Заключение

Группы кнопок — это неотъемлемый элемент современных веб-интерфейсов. Их правильное использование поможет сделать ваше приложение более удобным и интуитивно понятным для пользователей. Не забывайте следовать лучшим практикам и экспериментировать с разными стилями, чтобы создать наилучший пользовательский опыт. Удачи в разработке!