使用Bootstrap的自定义按钮样式来操作表单、对话框等,并支持多种大小、状态等。

示例

Bootstrap包括几个预定义的按钮样式,每个样式都有自己的语义目的,还有一些额外的控件。

<button type="button" class="btn btn-primary">Primary</button>
<button type="button" class="btn btn-secondary">Secondary</button>
<button type="button" class="btn btn-success">Success</button>
<button type="button" class="btn btn-danger">Danger</button>
<button type="button" class="btn btn-warning">Warning</button>
<button type="button" class="btn btn-info">Info</button>
<button type="button" class="btn btn-light">Light</button>
<button type="button" class="btn btn-dark">Dark</button>

<button type="button" class="btn btn-link">Link</button>
向辅助技术传达意义

使用颜色来增加意义只提供了一种视觉指示,而不会向辅助技术(如屏幕阅读器)的用户传达这种指示。确保用颜色表示的信息从内容本身来看是明显的(例如可见文本),或者是通过其他方法包括进来的,例如用 .visually-hidden 类隐藏的附加文本。

禁止文字换行

如果你不想让按钮文本自动换行,你可以添加 .text-nowrap 类到按钮。在Sass中,你可以设置 $btn-white-space: nowrap 来禁用每个按钮的文本换行。

按钮标签

.btn 类旨在与 <button> 元素一起使用。 但是,您也可以在 <a><input> 元素上使用这些类(尽管某些浏览器可能会使用略有不同的呈现方式)。

<a> 元素上使用按钮类来触发页面内功能(如折叠内容)时,而不是链接到当前页面中的新页面或新部分时,应为这些链接赋予相应的角色 role="button" 将其目的传达给辅助技术,例如屏幕阅读器。

Link
<a class="btn btn-primary" href="#" role="button">Link</a>
<button class="btn btn-primary" type="submit">Button</button>
<input class="btn btn-primary" type="button" value="Input">
<input class="btn btn-primary" type="submit" value="Submit">
<input class="btn btn-primary" type="reset" value="Reset">

轮廓按钮

需要一个按钮,但是他们带来的沉重背景颜色不是吗? 用 .btn-outline-* 替换默认修饰符类,以删除任何按钮上的所有背景图像和颜色。

<button type="button" class="btn btn-outline-primary">Primary</button>
<button type="button" class="btn btn-outline-secondary">Secondary</button>
<button type="button" class="btn btn-outline-success">Success</button>
<button type="button" class="btn btn-outline-danger">Danger</button>
<button type="button" class="btn btn-outline-warning">Warning</button>
<button type="button" class="btn btn-outline-info">Info</button>
<button type="button" class="btn btn-outline-light">Light</button>
<button type="button" class="btn btn-outline-dark">Dark</button>
一些按钮样式使用了相对较淡的前景色,并且应该只在深色背景上使用,以便有足够的对比度。

按钮大小

喜欢大一点的按钮还是小一点的按钮?增加 .btn-lg.btn-sm 的额外尺寸。

<button type="button" class="btn btn-primary btn-lg">Large button</button>
<button type="button" class="btn btn-secondary btn-lg">Large button</button>
<button type="button" class="btn btn-primary btn-sm">Small button</button>
<button type="button" class="btn btn-secondary btn-sm">Small button</button>

禁用按钮

通过将 disabled 的boolean属性添加到任何 <button> 元素,可使按钮看起来不活动。 禁用的按钮具有 pointer-events: none 未应用任何指针事件,以防止触发悬停和活动状态。

<button type="button" class="btn btn-lg btn-primary" disabled>Primary button</button>
<button type="button" class="btn btn-secondary btn-lg" disabled>Button</button>

使用 <a> 元素的禁用按钮的行为略有不同:

  • <a> 不支持disabled属性,因此您必须添加 .disabled 类以使其在外观上看起来是禁用的。
  • 包括一些将来友好的样式,以禁用锚点按钮上的所有 pointer-events
  • 禁用的按钮应包含 aria-disabled="true" 属性,以向辅助技术指示元素的状态。
<a href="#" class="btn btn-primary btn-lg disabled" tabindex="-1" role="button" aria-disabled="true">Primary link</a>
<a href="#" class="btn btn-secondary btn-lg disabled" tabindex="-1" role="button" aria-disabled="true">Link</a>

.disabled 类使用 pointer-events: none 试图禁用 <a> 的链接功能,但是CSS属性尚未标准化。 此外,即使在支持 pointer-events: none 的浏览器中,键盘导航也不会受到影响,这意味着有经验的键盘用户和辅助技术用户仍将能够激活这些链接。 因此,为了安全起见,除了 aria-disabled="true"之外,还应在这些链接上包含 tabindex="-1" 属性,以防止它们接收键盘焦点,并使用自定义JavaScript完全禁用其功能。

块级按钮

混合使用我们的显示和间隙实用工具,创建像Bootstrap 4中一样的全宽度“阻止按钮”响应式堆栈。 通过使用实用工具而不是按钮特定的类,我们可以更好地控制间距,对齐方式和响应行为。

<div class="d-grid gap-2">
<button class="btn btn-primary" type="button">Button</button>
<button class="btn btn-primary" type="button">Button</button>
</div>

在这里,我们创建了一个响应式变化,从垂直堆叠的按钮开始,直到 md 断点为止,在该断点处, .d-md-block 替换了 .d-grid 类,从而使 gap-2 实用工具无效。 调整浏览器大小以查看它们的变化。

<div class="d-grid gap-2 d-md-block">
<button class="btn btn-primary" type="button">Button</button>
<button class="btn btn-primary" type="button">Button</button>
</div>

您可以使用网格列宽度类来调整块按钮的宽度。 例如,对于半角的“阻止按钮”,请使用 .col-6。 也可以使用 .mx-auto 将其水平居中。

<div class="d-grid gap-2 col-6 mx-auto">
<button class="btn btn-primary" type="button">Button</button>
<button class="btn btn-primary" type="button">Button</button>
</div>

其他实用工具可用于水平调整按钮的对齐方式。这里,我们采用了前面的响应式示例,并在按钮上添加了一些flex实用工具和一个边距实用工具,以便在按钮不再堆叠时右对齐。

<div class="d-grid gap-2 d-md-flex justify-content-md-end">
<button class="btn btn-primary me-md-2" type="button">Button</button>
<button class="btn btn-primary" type="button">Button</button>
</div>

按钮插件

按钮插件允许你创建简单的开/关切换按钮。

从视觉上看,这些切换按钮与复选框切换按钮相同。然而,通过辅助技术,它们的表达方式是不同的:复选框切换将被屏幕阅读器宣布为“已选中”/“未选中”(因为,尽管它们的外观,它们基本上仍然是复选框),而这些切换按钮将被宣布为“按钮”/“按钮已按下”。这两种方法的选择取决于您要创建的切换类型,以及当将该切换宣布为复选框或实际按钮时,用户是否有意义。

切换状态

添加 data-bs-toggle="button" 可以切换按钮的 active 状态。 如果要预切换按钮,则必须手动添加 .active aria-pressed="true" ,以确保将其适当地传达给辅助技术。

<button type="button" class="btn btn-primary" data-bs-toggle="button" autocomplete="off">Toggle button</button>
<button type="button" class="btn btn-primary active" data-bs-toggle="button" autocomplete="off" aria-pressed="true">Active toggle button</button>
<button type="button" class="btn btn-primary" disabled data-bs-toggle="button" autocomplete="off">Disabled toggle button</button>
<a href="#" class="btn btn-primary" role="button" data-bs-toggle="button">Toggle link</a>
<a href="#" class="btn btn-primary active" role="button" data-bs-toggle="button" aria-pressed="true">Active toggle link</a>
<a href="#" class="btn btn-primary disabled" tabindex="-1" aria-disabled="true" role="button" data-bs-toggle="button">Disabled toggle link</a>

方法

你可以用button构造函数创建一个button实例,例如:

var button = document.getElementById('myButton')
var bsButton = new bootstrap.Button(button)
方法 描述
toggle 切换状态。使按钮显示为已被激活。
dispose 销毁元素的按钮。(删除DOM元素上存储的数据)

For example, to toggle all buttons

var buttons = document.querySelectorAll('.btn')
buttons.forEach(function (button) {
var button = new bootstrap.Button(button)
button.toggle()
})