Component aliases
<b-button> can also be used via the following aliases:
<b-btn>
Note: component aliases are only available when importing all of BootstrapVue or using the component group plugin.
Use Bootstrap's custom b-button component for actions in forms, dialogs, and more. Includes
support for a handful of contextual variations, sizes, states, and more.
<div>
<b-button>Button</b-button>
<b-button variant="danger">Button</b-button>
<b-button variant="success">Button</b-button>
<b-button variant="outline-primary">Button</b-button>
</div>
<!-- b-button.vue -->The <b-button> component generally renders a <button> element. However, you can also render an
<a> element by providing an href prop value. You may also generate vue-router <router-link>
when providing a value for the to prop (vue-router is required).
<div>
<b-button>I am a Button</b-button>
<b-button href="#">I am a Link</b-button>
</div>
<!-- b-button-types.vue -->You can specify the button's type by setting the prop type to 'button', 'submit' or 'reset'.
The default type is 'button'.
Note the type prop has no effect when either href or to props are set.
Fancy larger or smaller buttons? Specify lg or sm via the size prop.
<b-row>
<b-col lg="4" class="pb-2"><b-button size="sm">Small Button</b-button></b-col>
<b-col lg="4" class="pb-2"><b-button>Default Button</b-button></b-col>
<b-col lg="4" class="pb-2"><b-button size="lg">Large Button</b-button></b-col>
</b-row>
<!-- b-button-sizes.vue -->Use the variant prop to generate the various Bootstrap contextual button variants.
By default <b-button> will render with the secondary variant.
The variant prop adds the Bootstrap v4.3 class .btn-<variant> on the rendered button.
primary, secondary, success, danger, warning, info, light and dark.
<div>
<b-button variant="primary">Primary</b-button>
<b-button variant="secondary">Secondary</b-button>
<b-button variant="success">Success</b-button>
<b-button variant="danger">Danger</b-button>
<b-button variant="warning">Warning</b-button>
<b-button variant="info">Info</b-button>
<b-button variant="light">Light</b-button>
<b-button variant="dark">Dark</b-button>
</div>
<!-- b-button-solid.vue -->In need of a button, but not the hefty background colors they bring? Use the outline-* variants to
remove all background images and colors on any <b-button>:
outline-primary, outline-secondary, outline-success, outline-danger, outline-warning,
outline-info, outline-light and outline-dark.
<div>
<b-button variant="outline-primary">Primary</b-button>
<b-button variant="outline-secondary">Secondary</b-button>
<b-button variant="outline-success">Success</b-button>
<b-button variant="outline-danger">Danger</b-button>
<b-button variant="outline-warning">Warning</b-button>
<b-button variant="outline-info">Info</b-button>
<b-button variant="outline-light">Light</b-button>
<b-button variant="outline-dark">Dark</b-button>
</div>
<!-- b-button-outline.vue -->Variant link will render a button with the appearance of a link while maintaining the default
padding and size of a button.
<div>
<b-button variant="link">Link</b-button>
</div>
<!-- b-button-link.vue -->Tip: remove the hover underline from a link variant button by adding the Bootstrap v4.3 utility
class text-decoration-none to <b-button>.
Create block level buttons — those that span the full width of a parent — by setting the block
prop.
<div>
<b-button block variant="primary">Block Level Button</b-button>
</div>
<!-- b-button-block.vue -->NEW in 2.0.0-rc.20
Prefer buttons with a more rounded-pill style? Just set the prop pill to true.
<div>
<b-button pill>Button</b-button>
<b-button pill variant="primary">Button</b-button>
<b-button pill variant="outline-secondary">Button</b-button>
<b-button pill variant="success">Button</b-button>
<b-button pill variant="outline-danger">Button</b-button>
<b-button pill variant="info">Button</b-button>
</div>
<!-- b-button-pill.vue -->This prop adds the Bootstrap v4.3 utility class .rounded-pill on the rendered button.
NEW in 2.0.0-rc.22
Prefer buttons with a more square corner style? Just set the prop squared to true.
<div>
<b-button squared>Button</b-button>
<b-button squared variant="primary">Button</b-button>
<b-button squared variant="outline-secondary">Button</b-button>
<b-button squared variant="success">Button</b-button>
<b-button squared variant="outline-danger">Button</b-button>
<b-button squared variant="info">Button</b-button>
</div>
<!-- b-button-square.vue -->The squared prop adds the Bootstrap v4.3 utility class .rounded-0 on the rendered button. The
pill prop takes precedence over the squared prop.
Set the disabled prop to disable button default functionality. disabled also works with buttons
rendered as <a> elements and <router-link> (i.e. with the href or to prop set).
<div>
<b-button disabled size="lg" variant="primary">Disabled</b-button>
<b-button disabled size="lg">Also Disabled</b-button>
</div>
<!-- b-button-disabled.vue -->Buttons will appear pressed (with a darker background, darker border, and inset shadow) when the
prop pressed is set to true.
The pressed prop can be set to one of three values:
true: Sets the .active class and adds the attribute aria-pressed="true".false: Clears the .active class and adds the attribute aria-pressed="false".null: (default) Neither the class .active nor the attribute aria-pressed will be set.To create a button that can be toggled between active and non-active states, use the .sync prop
modifier (available in Vue 2.3+) on the pressed property
<template>
<div>
<h5>Pressed and un-pressed state</h5>
<b-button :pressed="true" variant="success">Always Pressed</b-button>
<b-button :pressed="false" variant="success">Not Pressed</b-button>
<h5 class="mt-3">Toggleable Button</h5>
<b-button :pressed.sync="myToggle" variant="primary">Toggle Me</b-button>
<p>Pressed State: <strong>{{ myToggle }}</strong></p>
<h5>In a button group</h5>
<b-button-group size="sm">
<b-button
v-for="(btn, idx) in buttons"
:key="idx"
:pressed.sync="btn.state"
variant="primary"
>
{{ btn.caption }}
</b-button>
</b-button-group>
<p>Pressed States: <strong>{{ btnStates }}</strong></p>
</div>
</template>
<script>
export default {
data() {
return {
myToggle: false,
buttons: [
{ caption: 'Toggle 1', state: true },
{ caption: 'Toggle 2', state: false },
{ caption: 'Toggle 3', state: true },
{ caption: 'Toggle 4', state: false }
]
}
},
computed: {
btnStates() {
return this.buttons.map(btn => btn.state)
}
}
}
</script>
<!-- b-button-toggles.vue -->If using toggle button style for a radio or checkbox style interface, it is best to use the built-in
button style support of <b-form-radio-group> and
<b-form-checkbox-group>.
Refer to the Router support reference docs for the various
supported <router-link> related props.
Note the <router-link> prop tag is referred to as router-tag in bootstrap-vue.
<b-button><b-button> can also be used via the following aliases:
<b-btn>Note: component aliases are only available when importing all of BootstrapVue or using the component group plugin.
| Property | Type | Default Value |
|---|---|---|
href | String | |
rel | String | |
target | String | _self |
active | Boolean | false |
disabled | Boolean | false |
to | String or Object | |
append | Boolean | false |
replace | Boolean | false |
event | String or Array | click |
active-class | String | |
exact | Boolean | false |
exact-active-class | String | |
router-tag | String | a |
no-prefetch | Boolean | false |
block | Boolean | false |
size | String | |
variant | String | secondary |
type | String | button |
tag | String | button |
pill | Boolean | false |
squared | Boolean | false |
pressed | Boolean |
| Event | Arguments | Description |
|---|---|---|
click | Native click event object | Emitted when non-disabled button clicked |
<b-button-close><b-button-close> can also be used via the following aliases:
<b-btn-close>Note: component aliases are only available when importing all of BootstrapVue or using the component group plugin.
| Property | Type | Default Value |
|---|---|---|
disabled | Boolean | false |
aria-label | String | Close |
text-variant | String |
| Event | Arguments | Description |
|---|---|---|
click | Native click event object | Emitted when non-disabled button clicked |
CHANGED in 2.0.0-rc.22 You can import individual components into your project via the following named exports:
| Component | Named Export | Import Path |
|---|---|---|
<b-button> | BButton | bootstrap-vue |
<b-button-close> | BButtonClose | bootstrap-vue |
Example:
import { BButton } from 'bootstrap-vue'
Vue.component('b-button', BButton)CHANGED in 2.0.0-rc.22 Importing plugins has been simplified.
This plugin includes all of the above listed individual components. Plugins also include any component aliases.
| Named Export | Import Path |
|---|---|
ButtonPlugin | bootstrap-vue |
Example:
import { ButtonPlugin } from 'bootstrap-vue'
Vue.use(ButtonPlugin)