Skip to main content Skip to docs navigation

Button group

Group a series of buttons together on a single line or stack them in a vertical column.

Basic example

Wrap a series of buttons in .btn-group.

HTML
<div class="btn-group" role="group" aria-label="Basic example">
  <button type="button" class="btn-solid theme-primary">Left</button>
  <button type="button" class="btn-solid theme-primary">Middle</button>
  <button type="button" class="btn-solid theme-primary">Right</button>
</div>

Button groups require an appropriate role attribute and explicit label to ensure assistive technologies like screen readers identify buttons as grouped and announce them. Use role="group" for button groups or role="toolbar" for button toolbars. Then use aria-label or aria-labelledby to label them.

These classes can also be added to groups of links, as an alternative to the .nav navigation components.

HTML
<div class="btn-group">
  <a href="#" class="btn-solid theme-primary active" aria-current="page">Active link</a>
  <a href="#" class="btn-solid theme-primary">Link</a>
  <a href="#" class="btn-solid theme-primary">Link</a>
</div>

Mixed variants

HTML
<div class="btn-group" role="group" aria-label="Basic mixed styles example">
  <button type="button" class="btn-solid theme-danger">Left</button>
  <button type="button" class="btn-solid theme-warning">Middle</button>
  <button type="button" class="btn-solid theme-success">Right</button>
</div>

Outline buttons

HTML
<div class="btn-group" role="group" aria-label="Basic outlined example">
  <button type="button" class="btn-outline theme-primary">Left</button>
  <button type="button" class="btn-outline theme-primary">Middle</button>
  <button type="button" class="btn-outline theme-primary">Right</button>
</div>

Toggle buttons

Checkbox

Checkbox toggle buttons can be grouped together. Any or all of the buttons can be checked.

HTML
<div class="btn-group" role="group" aria-label="Basic checkbox toggle button group">
  <label class="btn-check btn-outline theme-primary">
    <input type="checkbox" autocomplete="off">
    Checkbox 1
  </label>
  <label class="btn-check btn-outline theme-primary">
    <input type="checkbox" autocomplete="off">
    Checkbox 2
  </label>
  <label class="btn-check btn-outline theme-primary">
    <input type="checkbox" autocomplete="off">
    Checkbox 3
  </label>
</div>

Radio

By design, radio toggle button groups can only have one button checked at a time.

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

Button toolbar

Combine sets of button groups into button toolbars for more complex components. Use utility classes as needed to space out groups, buttons, and more.

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

Feel free to mix input groups with button groups in your toolbars. Similar to the example above, you'll likely need some utilities though to space things properly.

HTML
<div class="btn-toolbar" role="toolbar" aria-label="Toolbar with button groups">
  <div class="btn-group" role="group" aria-label="First group">
    <button type="button" class="btn-outline theme-secondary">1</button>
    <button type="button" class="btn-outline theme-secondary">2</button>
    <button type="button" class="btn-outline theme-secondary">3</button>
    <button type="button" class="btn-outline theme-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-outline theme-secondary">1</button>
    <button type="button" class="btn-outline theme-secondary">2</button>
    <button type="button" class="btn-outline theme-secondary">3</button>
    <button type="button" class="btn-outline theme-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>

Sizing

Instead of applying button sizing classes to every button in a group, just add .btn-group-* to each .btn-group, including each one when nesting multiple groups.

HTML
<div class="btn-group btn-group-lg" role="group" aria-label="Large button group">
  <button type="button" class="btn-outline theme-primary">Left</button>
  <button type="button" class="btn-outline theme-primary">Middle</button>
  <button type="button" class="btn-outline theme-primary">Right</button>
</div>
<div class="btn-group" role="group" aria-label="Default button group">
  <button type="button" class="btn-outline theme-primary">Left</button>
  <button type="button" class="btn-outline theme-primary">Middle</button>
  <button type="button" class="btn-outline theme-primary">Right</button>
</div>
<div class="btn-group btn-group-sm" role="group" aria-label="Small button group">
  <button type="button" class="btn-outline theme-primary">Left</button>
  <button type="button" class="btn-outline theme-primary">Middle</button>
  <button type="button" class="btn-outline theme-primary">Right</button>
</div>
<div class="btn-group btn-group-xs" role="group" aria-label="Extra small button group">
  <button type="button" class="btn-outline theme-primary">Left</button>
  <button type="button" class="btn-outline theme-primary">Middle</button>
  <button type="button" class="btn-outline theme-primary">Right</button>
</div>

Nesting

Place a .btn-group within another .btn-group when you want dropdown menus mixed with a series of buttons.

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

  <div class="btn-group" role="group">
    <button type="button" class="btn-solid theme-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>

Vertical variation

Make a set of buttons appear vertically stacked rather than horizontally. Split button dropdowns are not supported here.

HTML
<div class="btn-group-vertical" role="group" aria-label="Vertical button group">
  <button type="button" class="btn-solid theme-primary">Button</button>
  <button type="button" class="btn-solid theme-primary">Button</button>
  <button type="button" class="btn-solid theme-primary">Button</button>
  <button type="button" class="btn-solid theme-primary">Button</button>
</div>
HTML
<div class="btn-group-vertical" role="group" aria-label="Vertical button group">
  <div class="btn-group" role="group">
    <button type="button" class="btn-solid theme-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>
  <button type="button" class="btn-solid theme-primary">Button</button>
  <button type="button" class="btn-solid theme-primary">Button</button>
  <div class="btn-group dropstart" role="group">
    <button type="button" class="btn-solid theme-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-solid theme-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-solid theme-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>
HTML
<div class="btn-group-vertical" role="group" aria-label="Vertical radio toggle button group">
  <label class="btn-check btn-outline theme-danger">
    <input type="radio" name="vbtn-radio" autocomplete="off" checked>
    Radio 1
  </label>
  <label class="btn-check btn-outline theme-danger">
    <input type="radio" name="vbtn-radio" autocomplete="off">
    Radio 2
  </label>
  <label class="btn-check btn-outline theme-danger">
    <input type="radio" name="vbtn-radio" autocomplete="off">
    Radio 3
  </label>
</div>