按钮
使用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"
将其目的传达给辅助技术,例如屏幕阅读器。
<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()
})