按钮组(Button group)

通过按钮组将一系列按钮分组在一起,并使用JavaScript对它们进行超级处理。

基础示例

在.btn-group中将一系列带有.btn的按钮包装起来。 通过our buttons plugin添加可选的JavaScript单选和复选框样式行为。

<div class="btn-group" role="group" aria-label="Basic example">
  <button type="button" class="btn btn-secondary">Left</button>
  <button type="button" class="btn btn-secondary">Middle</button>
  <button type="button" class="btn btn-secondary">Right</button>
</div>
确保正确的“角色”并提供标签

为了使辅助技术(例如屏幕阅读器)传达一系列按钮已分组的信息,需要提供适当的“角色”属性。 对于按钮组,这将是role =“ group”,而工具栏应具有role =“ toolbar”

此外,应该为组和工具栏指定一个明确的标签,因为尽管存在正确的角色属性,但大多数辅助技术都不会宣布它们。 在此处提供的示例中,我们使用“ aria-label”,但也可以使用“ aria-labelledby”之类的替代方式。

按钮工具栏

将按钮组集合组合到按钮工具栏中,以获取更复杂的组件。 根据需要使用实用程序类来分隔组,按钮等。

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

随意将输入组与工具栏中的按钮组混合使用。 与上面的示例类似,您可能需要一些实用程序来适当地隔开空间。

<div class="btn-toolbar mb-3" role="toolbar" aria-label="Toolbar with button groups">
  <div class="btn-group mr-2" role="group" aria-label="First group">
    <button type="button" class="btn btn-secondary">1</button>
    <button type="button" class="btn btn-secondary">2</button>
    <button type="button" class="btn btn-secondary">3</button>
    <button type="button" class="btn btn-secondary">4</button>
  </div>
  <div class="input-group">
    <div class="input-group-prepend">
      <div class="input-group-text" id="btnGroupAddon">@</div>
    </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-secondary">1</button>
    <button type="button" class="btn btn-secondary">2</button>
    <button type="button" class="btn btn-secondary">3</button>
    <button type="button" class="btn btn-secondary">4</button>
  </div>
  <div class="input-group">
    <div class="input-group-prepend">
      <div class="input-group-text" id="btnGroupAddon2">@</div>
    </div>
    <input type="text" class="form-control" placeholder="Input group example" aria-label="Input group example" aria-describedby="btnGroupAddon2">
  </div>
</div>

尺寸(Sizing)

不必对组中的每个按钮应用按钮大小设置类,只需将.btn-group- *添加到每个.btn-group中,包括嵌套多个组时的每个组件。



<div class="btn-group btn-group-lg" role="group" aria-label="...">...</div>
<div class="btn-group" role="group" aria-label="...">...</div>
<div class="btn-group btn-group-sm" role="group" aria-label="...">...</div>

嵌套(Nesting)

当您想要将下拉菜单与一系列按钮混合使用时,请将.btn-group放在另一个.btn-group中。

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

  <div class="btn-group" role="group">
    <button id="btnGroupDrop1" type="button" class="btn btn-secondary dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
      Dropdown
    </button>
    <div class="dropdown-menu" aria-labelledby="btnGroupDrop1">
      <a class="dropdown-item" href="#">Dropdown link</a>
      <a class="dropdown-item" href="#">Dropdown link</a>
    </div>
  </div>
</div>

垂直变化

使一组按钮垂直堆叠而不是水平堆叠。 此处不支持拆分按钮下拉菜单。

<div class="btn-group-vertical">
  ...
</div>