Saltearse al contenido

Componentes de Botones de Bootstrap

Usa los estilos de botones personalizados de Bootstrap para acciones en formularios, cuadros de diálogo y más con soporte para múltiples tamaños, estados y más.

Clase base de Botones

Bootstrap tiene una clase base .btn que configura estilos básicos como relleno y alineación de contenido. De forma predeterminada, los controles .btn tienen un borde transparente y un color de fondo, y carecen de enfoque explícito y estilos de desplazamiento.

HTML
<button type="button" class="btn">Clase base</button>

La clase .btn está diseñada para usarse junto con nuestras variantes de botones o para servir como base para tus propios estilos personalizados.

Variantes para estilos de Botones

Bootstrap incluye varias variantes de botones, cada una con su propio propósito semántico, con algunos extras agregados para mayor control.

HTML
<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">Enlace</button>

Desactivar el ajuste de texto

Si no quieres que el texto del botón se ajuste, puedes agregar la clase .text-nowrap al botón. En Sass, puedes configurar $btn-white-space: nowrap para deshabilitar el ajuste de texto para cada botón.

Otras etiquetas con estilos de botones

Las clases .btn están diseñadas para usarse con el elemento <button>. Sin embargo, también puedes utilizar estas clases en elementos <a> o <input> (aunque algunos navegadores pueden aplicar una representación ligeramente diferente).

Cuando usas clases de botones en elementos <a> que se usan para activar la funcionalidad en la página (como contraer contenido), en lugar de vincular a páginas nuevas o secciones dentro de la página actual, a estos enlaces se les debe asignar un role="button" para transmitir adecuadamente su propósito a tecnologías de asistencia como lectores de pantalla.

HTML
<a class="btn btn-primary" href="#" role="button">Enlace</a>
<button class="btn btn-primary" type="submit">Botón</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">

Botones con estilo de contorno

¿Necesitas un botón, pero no los fuertes colores de fondo que traen? Reemplaza las clases modificadoras predeterminadas con las .btn-outline-* para eliminar todas las imágenes de fondo y colores en cualquier botón.

HTML
<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>

Tamaños de Botones

¿Te apetece botones más grandes o más pequeños? Agrega .btn-lg o .btn-sm para tamaños adicionales.

HTML
<button type="button" class="btn btn-primary btn-lg">Botón grande</button>
<button type="button" class="btn btn-secondary btn-lg">Botón grande</button>
HTML
<button type="button" class="btn btn-primary btn-sm">Botón pequeño</button>
<button type="button" class="btn btn-secondary btn-sm">Botón pequeño</button>

Incluso puedes crear tu propio tamaño personalizado con variables CSS:

HTML
<button type="button" class="btn btn-primary" style="--bs-btn-padding-y: .25rem; --bs-btn-padding-x: .5rem; --bs-btn-font-size: .75rem;">
Botón personalizado
</button>

Estado deshabilitado de Botones

Haz que los botones parezcan inactivos agregando el atributo booleano disabled a cualquier elemento <button>. Los botones deshabilitados tienen pointer-events: none aplicados, lo que evita que se activen los estados active y hover.

HTML
<button type="button" class="btn btn-primary" disabled="">Botón principal</button>
<button type="button" class="btn btn-secondary" disabled="">Botón</button>
<button type="button" class="btn btn-outline-primary" disabled="">Botón principal</button>
<button type="button" class="btn btn-outline-secondary" disabled="">Botón</button>

Los botones deshabilitados que usan el elemento <a> se comportan un poco diferente:

  • <a> no admite el atributo disabled, por lo que debes agregar la clase .disabled para que parezca visualmente deshabilitado.
  • Se incluyen algunos estilos aptos para el futuro para deshabilitar todos los pointer-events en los botones de anclaje.
  • Los botones deshabilitados que usan <a> deben incluir el atributo aria-disabled="true" para indicar el estado del elemento a las tecnologías de asistencia.
  • Los botones deshabilitados que usan <a> no deben incluir el atributo href.
HTML
<a class="btn btn-primary disabled" role="button" aria-disabled="true">Enlace principal</a>
<a class="btn btn-secondary disabled" role="button" aria-disabled="true">Enlace</a>

Para cubrir casos en los que tienes que mantener el atributo href en un enlace deshabilitado, la clase .disabled usa pointer-events: none para intentar deshabilitar la funcionalidad de enlace de <a>s. Ten en cuenta que esta propiedad CSS aún no está estandarizada para HTML, pero todos los navegadores modernos la admiten. Además, incluso en los navegadores que admiten pointer-events: none, la navegación con el teclado no se ve afectada, lo que significa que los usuarios de teclados videntes y los usuarios de tecnologías de asistencia aún podrán activar estos enlaces. Por lo tanto, para estar seguro, además de aria-disabled="true", incluya también un atributo tabindex="-1" en estos enlaces para evitar que reciban el foco del teclado y utiliza JavaScript personalizado para desactivar su funcionalidad por completo.

HTML
<a href="#" class="btn btn-primary disabled" tabindex="-1" role="button" aria-disabled="true">Enlace principal</a>
<a href="#" class="btn btn-secondary disabled" tabindex="-1" role="button" aria-disabled="true">Enlace</a>

Bloque de botones

Crea pilas responsive de “botones de bloque” de ancho completo como los de Bootstrap 4 con una combinación de nuestras utilidades de visualización y espacios. Al utilizar utilidades en lugar de clases específicas de botones, tenemos mucho mayor control sobre el espaciado, la alineación y los comportamientos responsive.

HTML
<div class="d-grid gap-2">
<button class="btn btn-primary" type="button">Botón</button>
<button class="btn btn-primary" type="button">Botón</button>
</div>

Aquí creamos una variación responsive, comenzando con botones apilados verticalmente hasta el punto de interrupción md, donde .d-md-block reemplaza la clase .d-grid, sobrescribendo así la utilidad gap-2. Cambia el tamaño de tu navegador para verlos cambiar.

HTML
<div class="d-grid gap-2 d-md-block">
<button class="btn btn-primary" type="button">Botón</button>
<button class="btn btn-primary" type="button">Botón</button>
</div>

Puedes ajustar el ancho de tus botones de bloque con clases de ancho de columna de la cuadrícula. Por ejemplo, para un “botón de bloqueo” de ancho medio, utilice .col-6. Céntralo también horizontalmente con .mx-auto.

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

Se pueden usar utilidades adicionales para ajustar la alineación de los botones cuando están horizontales. Aquí tomamos nuestro ejemplo responsive anterior y agregamos algunas utilidades flexibles y una utilidad de margen en el botón para alinear los botones a la derecha cuando ya no están apilados.

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

Complemento de botón

El complemento de botones te permite crear botones simples de activación/desactivación.

Alternar estados

Agrega data-bs-toggle="button" para alternar el estado active de un botón. Si está alternando previamente un botón, debes agregar manualmente .active (clase) y aria-pressed="true" para garantizar que se transmite adecuadamente a las tecnologías de asistencia.

HTML
<p class="d-inline-flex gap-1">
<button type="button" class="btn" data-bs-toggle="button">Botón de alternar</button>
<button type="button" class="btn active" data-bs-toggle="button" aria-pressed="true">Botón de alternancia activo</button>
<button type="button" class="btn" disabled="" data-bs-toggle="button">Botón de alternancia deshabilitado</button>
</p>
<p class="d-inline-flex gap-1">
<button type="button" class="btn btn-primary" data-bs-toggle="button">Botón de alternar</button>
<button type="button" class="btn btn-primary active" data-bs-toggle="button" aria-pressed="true">Botón de alternancia activo</button>
<button type="button" class="btn btn-primary" disabled="" data-bs-toggle="button">Botón de alternancia deshabilitado</button>
</p>
HTML
<p class="d-inline-flex gap-1">
<a href="#" class="btn" role="button" data-bs-toggle="button">Enlace de alternar</a>
<a href="#" class="btn active" role="button" data-bs-toggle="button" aria-pressed="true">Enlace de alternancia activo</a>
<a class="btn disabled" aria-disabled="true" role="button" data-bs-toggle="button">Enlace de alternancia deshabilitado</a>
</p>
<p class="d-inline-flex gap-1">
<a href="#" class="btn btn-primary" role="button" data-bs-toggle="button">Enlace de alternar</a>
<a href="#" class="btn btn-primary active" role="button" data-bs-toggle="button" aria-pressed="true">Enlace de alternancia activo</a>
<a class="btn btn-primary disabled" aria-disabled="true" role="button" data-bs-toggle="button">Enlace de alternancia deshabilitado</a>
</p>

Métodos

Puedes crear una instancia de botón con el constructor de botones, por ejemplo:

JavaScript
const bsButton = new bootstrap.Button('#myButton')
MétodoDescripción
disposeDestruye el botón de un elemento. (Elimina los datos almacenados en el elemento DOM)
getInstanceMétodo estático que te permite obtener la instancia del botón asociada con un elemento DOM, puedes usarlo así: bootstrap.Button.getInstance(element).
getOrCreateInstanceMétodo estático que devuelve una instancia de botón asociada con un elemento DOM o crea uno nuevo en caso de que no haya sido inicializado. Puedes usarlo así: bootstrap.Button.getOrCreateInstance(element).
toggleCambia el estado de presionado. Le da al botón la apariencia de que ha sido activado.

Por ejemplo, para alternar todos los botones

JavaScript
document.querySelectorAll('.btn').forEach(buttonElement => {
const button = bootstrap.Button.getOrCreateInstance(buttonElement)
button.toggle()
})

Personalización del CSS del componente

Variables Sass del componente


Agregado en v5.2.0

Como parte del enfoque de variables CSS en evolución de Bootstrap, los botones ahora usan variables CSS locales en .btn para una personalización mejorada en tiempo real. Los valores de las variables CSS se establecen a través de Sass, por lo que la personalización de Sass también es compatible.

scss/_buttons.scss

scss/_buttons.scss
--#{$prefix}btn-padding-x: #{$btn-padding-x};
--#{$prefix}btn-padding-y: #{$btn-padding-y};
--#{$prefix}btn-font-family: #{$btn-font-family};
@include rfs($btn-font-size, --#{$prefix}btn-font-size);
--#{$prefix}btn-font-weight: #{$btn-font-weight};
--#{$prefix}btn-line-height: #{$btn-line-height};
--#{$prefix}btn-color: #{$btn-color};
--#{$prefix}btn-bg: transparent;
--#{$prefix}btn-border-width: #{$btn-border-width};
--#{$prefix}btn-border-color: transparent;
--#{$prefix}btn-border-radius: #{$btn-border-radius};
--#{$prefix}btn-hover-border-color: transparent;
--#{$prefix}btn-box-shadow: #{$btn-box-shadow};
--#{$prefix}btn-disabled-opacity: #{$btn-disabled-opacity};
--#{$prefix}btn-focus-box-shadow: 0 0 0 #{$btn-focus-width} rgba(var(--#{$prefix}btn-focus-shadow-rgb), .5);

Cada clase modificadora .btn-* actualiza las variables CSS apropiadas para minimizar reglas CSS adicionales con nuestros mixins button-variant(), button-outline-variant() y button-size().

Aquí tienes un ejemplo de cómo crear una clase modificadora .btn-* personalizada como lo hacemos para los botones exclusivos de nuestros documentación reasignando las variables CSS de Bootstrap con una mezcla de nuestras propias variables CSS y Sass.

site/assets/scss/_buttons.scss

site/assets/scss/_buttons.scss
.btn-bd-primary {
--bs-btn-font-weight: 600;
--bs-btn-color: var(--bs-white);
--bs-btn-bg: var(--bd-violet-bg);
--bs-btn-border-color: var(--bd-violet-bg);
--bs-btn-hover-color: var(--bs-white);
--bs-btn-hover-bg: #{shade-color($bd-violet, 10%)};
--bs-btn-hover-border-color: #{shade-color($bd-violet, 10%)};
--bs-btn-focus-shadow-rgb: var(--bd-violet-rgb);
--bs-btn-active-color: var(--bs-btn-hover-color);
--bs-btn-active-bg: #{shade-color($bd-violet, 20%)};
--bs-btn-active-border-color: #{shade-color($bd-violet, 20%)};
}

Variables Sass generales relacionadas

scss/_variables.scss

scss/_variables.scss
$btn-color: var(--#{$prefix}body-color);
$btn-padding-y: $input-btn-padding-y;
$btn-padding-x: $input-btn-padding-x;
$btn-font-family: $input-btn-font-family;
$btn-font-size: $input-btn-font-size;
$btn-line-height: $input-btn-line-height;
$btn-white-space: null; // Set to `nowrap` to prevent text wrapping
$btn-padding-y-sm: $input-btn-padding-y-sm;
$btn-padding-x-sm: $input-btn-padding-x-sm;
$btn-font-size-sm: $input-btn-font-size-sm;
$btn-padding-y-lg: $input-btn-padding-y-lg;
$btn-padding-x-lg: $input-btn-padding-x-lg;
$btn-font-size-lg: $input-btn-font-size-lg;
$btn-border-width: $input-btn-border-width;
$btn-font-weight: $font-weight-normal;
$btn-box-shadow: inset 0 1px 0 rgba($white, .15), 0 1px 1px rgba($black, .075);
$btn-focus-width: $input-btn-focus-width;
$btn-focus-box-shadow: $input-btn-focus-box-shadow;
$btn-disabled-opacity: .65;
$btn-active-box-shadow: inset 0 3px 5px rgba($black, .125);
$btn-link-color: var(--#{$prefix}link-color);
$btn-link-hover-color: var(--#{$prefix}link-hover-color);
$btn-link-disabled-color: $gray-600;
$btn-link-focus-shadow-rgb: to-rgb(mix(color-contrast($link-color), $link-color, 15%));
// Allows for customizing button radius independently from global border radius
$btn-border-radius: var(--#{$prefix}border-radius);
$btn-border-radius-sm: var(--#{$prefix}border-radius-sm);
$btn-border-radius-lg: var(--#{$prefix}border-radius-lg);
$btn-transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
$btn-hover-bg-shade-amount: 15%;
$btn-hover-bg-tint-amount: 15%;
$btn-hover-border-shade-amount: 20%;
$btn-hover-border-tint-amount: 10%;
$btn-active-bg-shade-amount: 20%;
$btn-active-bg-tint-amount: 20%;
$btn-active-border-shade-amount: 25%;
$btn-active-border-tint-amount: 10%;

Mixins Sass del componente

Hay tres combinaciones para botones: combinación de botón y variante de contorno de botón (ambas basadas en $theme-colors), además de una combinación de tamaño de botón.

scss/mixins/_buttons.scss

scss/mixins/_buttons.scss
@mixin button-variant(
$background,
$border,
$color: color-contrast($background),
$hover-background: if($color == $color-contrast-light, shade-color($background, $btn-hover-bg-shade-amount), tint-color($background, $btn-hover-bg-tint-amount)),
$hover-border: if($color == $color-contrast-light, shade-color($border, $btn-hover-border-shade-amount), tint-color($border, $btn-hover-border-tint-amount)),
$hover-color: color-contrast($hover-background),
$active-background: if($color == $color-contrast-light, shade-color($background, $btn-active-bg-shade-amount), tint-color($background, $btn-active-bg-tint-amount)),
$active-border: if($color == $color-contrast-light, shade-color($border, $btn-active-border-shade-amount), tint-color($border, $btn-active-border-tint-amount)),
$active-color: color-contrast($active-background),
$disabled-background: $background,
$disabled-border: $border,
$disabled-color: color-contrast($disabled-background)
) {
--#{$prefix}btn-color: #{$color};
--#{$prefix}btn-bg: #{$background};
--#{$prefix}btn-border-color: #{$border};
--#{$prefix}btn-hover-color: #{$hover-color};
--#{$prefix}btn-hover-bg: #{$hover-background};
--#{$prefix}btn-hover-border-color: #{$hover-border};
--#{$prefix}btn-focus-shadow-rgb: #{to-rgb(mix($color, $border, 15%))};
--#{$prefix}btn-active-color: #{$active-color};
--#{$prefix}btn-active-bg: #{$active-background};
--#{$prefix}btn-active-border-color: #{$active-border};
--#{$prefix}btn-active-shadow: #{$btn-active-box-shadow};
--#{$prefix}btn-disabled-color: #{$disabled-color};
--#{$prefix}btn-disabled-bg: #{$disabled-background};
--#{$prefix}btn-disabled-border-color: #{$disabled-border};
}

scss/mixins/_buttons.scss

scss/mixins/_buttons.scss
@mixin button-outline-variant(
$color,
$color-hover: color-contrast($color),
$active-background: $color,
$active-border: $color,
$active-color: color-contrast($active-background)
) {
--#{$prefix}btn-color: #{$color};
--#{$prefix}btn-border-color: #{$color};
--#{$prefix}btn-hover-color: #{$color-hover};
--#{$prefix}btn-hover-bg: #{$active-background};
--#{$prefix}btn-hover-border-color: #{$active-border};
--#{$prefix}btn-focus-shadow-rgb: #{to-rgb($color)};
--#{$prefix}btn-active-color: #{$active-color};
--#{$prefix}btn-active-bg: #{$active-background};
--#{$prefix}btn-active-border-color: #{$active-border};
--#{$prefix}btn-active-shadow: #{$btn-active-box-shadow};
--#{$prefix}btn-disabled-color: #{$color};
--#{$prefix}btn-disabled-bg: transparent;
--#{$prefix}btn-disabled-border-color: #{$color};
--#{$prefix}gradient: none;
}

scss/mixins/_buttons.scss

scss/mixins/_buttons.scss
@mixin button-size($padding-y, $padding-x, $font-size, $border-radius) {
--#{$prefix}btn-padding-y: #{$padding-y};
--#{$prefix}btn-padding-x: #{$padding-x};
@include rfs($font-size, --#{$prefix}btn-font-size);
--#{$prefix}btn-border-radius: #{$border-radius};
}

Bucles Sass del componente

Las variantes de botones (para botones regulares y de contorno) usan sus respectivos mixins con nuestro mapa $theme-colors para generar las clases modificadoras en scss/_buttons.scss.

scss/_buttons.scss

scss/_buttons.scss
@each $color, $value in $theme-colors {
.btn-#{$color} {
@if $color == "light" {
@include button-variant(
$value,
$value,
$hover-background: shade-color($value, $btn-hover-bg-shade-amount),
$hover-border: shade-color($value, $btn-hover-border-shade-amount),
$active-background: shade-color($value, $btn-active-bg-shade-amount),
$active-border: shade-color($value, $btn-active-border-shade-amount)
);
} @else if $color == "dark" {
@include button-variant(
$value,
$value,
$hover-background: tint-color($value, $btn-hover-bg-tint-amount),
$hover-border: tint-color($value, $btn-hover-border-tint-amount),
$active-background: tint-color($value, $btn-active-bg-tint-amount),
$active-border: tint-color($value, $btn-active-border-tint-amount)
);
} @else {
@include button-variant($value, $value);
}
}
}
@each $color, $value in $theme-colors {
.btn-outline-#{$color} {
@include button-outline-variant($value);
}
}

El componente Botón cerrar de Bootstrap

Un botón de cierre genérico para descartar contenido como modales y alertas.

Ejemplo del componente Botón cerrar

Proporciona una opción para descartar o cerrar un componente con .btn-close. El estilo predeterminado es limitado, pero altamente personalizable. Modifica las variables de Sass para reemplazar la background-image predeterminada. Asegúrate de incluir texto para lectores de pantalla, como hemos hecho con aria-label.

HTML
<button type="button" class="btn-close" aria-label="Cerrar"></button>

Estado deshabilitado del componente Botón cerrar

Los botones de cierre deshabilitados cambian su opacity. También hemos aplicado pointer-events: none y user-select: none para evitar que se activen los estados assets y de desplazamiento.

HTML
<button type="button" class="btn-close" disabled="" aria-label="Cerrar"></button>

Variante oscura del componente Botón cerrar


Obsoleto en v5.3.0

Agrega data-bs-theme="dark" al .btn-close, o a su elemento padre, para invertir el botón de cerrar. Esto utiliza la propiedad filter para invertir la background-image sin sobrescribir su valor.

HTML
<div data-bs-theme="dark">
<button type="button" class="btn-close" aria-label="Cerrar"></button>
<button type="button" class="btn-close" disabled="" aria-label="Cerrar"></button>
</div>

Personalización del CSS del componente

Variables Sass del componente


Agregado en v5.3.0

Como parte del enfoque de variables CSS en evolución de Bootstrap, el botón de cierre ahora usa variables CSS locales en .btn-close para una personalización mejorada en tiempo real. Los valores de las variables CSS se establecen a través de Sass, por lo que la personalización de Sass también es compatible.

scss/_close.scss

scss/_close.scss
--#{$prefix}btn-close-color: #{$btn-close-color};
--#{$prefix}btn-close-bg: #{ escape-svg($btn-close-bg) };
--#{$prefix}btn-close-opacity: #{$btn-close-opacity};
--#{$prefix}btn-close-hover-opacity: #{$btn-close-hover-opacity};
--#{$prefix}btn-close-focus-shadow: #{$btn-close-focus-shadow};
--#{$prefix}btn-close-focus-opacity: #{$btn-close-focus-opacity};
--#{$prefix}btn-close-disabled-opacity: #{$btn-close-disabled-opacity};
--#{$prefix}btn-close-white-filter: #{$btn-close-white-filter};

Variables Sass generales relacionadas

scss/_variables.scss

scss/_variables.scss
$btn-close-width: 1em;
$btn-close-height: $btn-close-width;
$btn-close-padding-x: .25em;
$btn-close-padding-y: $btn-close-padding-x;
$btn-close-color: $black;
$btn-close-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$btn-close-color}'><path d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/></svg>");
$btn-close-focus-shadow: $focus-ring-box-shadow;
$btn-close-opacity: .5;
$btn-close-hover-opacity: .75;
$btn-close-focus-opacity: 1;
$btn-close-disabled-opacity: .25;
$btn-close-white-filter: invert(1) grayscale(100%) brightness(200%);

El componente Grupo de botones de Bootstrap

Agrupa una serie de botones en una sola línea o apílalos en una columna vertical.

Ejemplo básico del componente Grupo de botones

Envuelve una serie de botones con .btn en .btn-group.

HTML
<div class="btn-group" role="group" aria-label="Ejemplo básico">
<button type="button" class="btn btn-primary">Izquierda</button>
<button type="button" class="btn btn-primary">Medio</button>
<button type="button" class="btn btn-primary">Derecha</button>
</div>

Estas clases también se pueden agregar a grupos de enlaces, como alternativa al .nav componentes de navegación.

HTML
<div class="btn-group">
<a href="#" class="btn btn-primary active" aria-current="page">Enlace activo</a>
<a href="#" class="btn btn-primary">Enlace</a>
<a href="#" class="btn btn-primary">Enlace</a>
</div>

Estilos mixtos del componente Grupo de botones

HTML
<div class="btn-group" role="group" aria-label="Ejemplo básico de estilos mixtos">
<button type="button" class="btn btn-danger">Izquierda</button>
<button type="button" class="btn btn-warning">Medio</button>
<button type="button" class="btn btn-success">Derecha</button>
</div>

Estilos outlined del componente Grupo de botones

HTML
<div class="btn-group" role="group" aria-label="Ejemplo básico outlined">
<button type="button" class="btn btn-outline-primary">Izquierda</button>
<button type="button" class="btn btn-outline-primary">Medio</button>
<button type="button" class="btn btn-outline-primary">Derecha</button>
</div>

Grupos de casillas de verificación y botones de opción

Combina botones de casilla de verificación y radio con forma de botones de alternancia en un grupo de botones de apariencia perfecta.

HTML
<div class="btn-group" role="group" aria-label="Grupo de botones de alternancia de casilla de verificación básico">
<input type="checkbox" class="btn-check" id="btncheck1" autocomplete="off">
<label class="btn btn-outline-primary" for="btncheck1">Casilla 1</label>
<input type="checkbox" class="btn-check" id="btncheck2" autocomplete="off">
<label class="btn btn-outline-primary" for="btncheck2">Casilla 2</label>
<input type="checkbox" class="btn-check" id="btncheck3" autocomplete="off">
<label class="btn btn-outline-primary" for="btncheck3">Casilla 3</label>
</div>
HTML
<div class="btn-group" role="group" aria-label="Grupo básico de botones de alternancia de radio">
<input type="radio" class="btn-check" name="btnradio" id="btnradio1" autocomplete="off" checked="">
<label class="btn btn-outline-primary" for="btnradio1">Radio 1</label>
<input type="radio" class="btn-check" name="btnradio" id="btnradio2" autocomplete="off">
<label class="btn btn-outline-primary" for="btnradio2">Radio 2</label>
<input type="radio" class="btn-check" name="btnradio" id="btnradio3" autocomplete="off">
<label class="btn btn-outline-primary" for="btnradio3">Radio 3</label>
</div>

Barra de herramientas de botones

Combina conjuntos de grupos de botones en barras de herramientas de botones para obtener componentes más complejos. Utiliza clases de utilidad según sea necesario para espaciar grupos, botones y más.

HTML
<div class="btn-toolbar" role="toolbar" aria-label="Barra de herramientas con grupos de botones">
<div class="btn-group me-2" role="group" aria-label="Primer grupo">
<button type="button" class="btn btn-primary">1</button>
<button type="button" class="btn btn-primary">2</button>
<button type="button" class="btn btn-primary">3</button>
<button type="button" class="btn btn-primary">4</button>
</div>
<div class="btn-group me-2" role="group" aria-label="Segundo grupo">
<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="Tercer grupo">
<button type="button" class="btn btn-info">8</button>
</div>
</div>

Siéntete libre de mezclar grupos de entrada con grupos de botones en tus barras de herramientas. Al igual que en el ejemplo anterior, es probable que necesites algunas utilidades para espaciar las cosas correctamente.

HTML
<div class="btn-toolbar mb-3" role="toolbar" aria-label="Barra de herramientas con grupos de botones">
<div class="btn-group me-2" role="group" aria-label="Primer grupo">
<button type="button" class="btn btn-outline-secondary">1</button>
<button type="button" class="btn btn-outline-secondary">2</button>
<button type="button" class="btn btn-outline-secondary">3</button>
<button type="button" class="btn btn-outline-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="Barra de herramientas con grupos de botones">
<div class="btn-group" role="group" aria-label="Primer grupo">
<button type="button" class="btn btn-outline-secondary">1</button>
<button type="button" class="btn btn-outline-secondary">2</button>
<button type="button" class="btn btn-outline-secondary">3</button>
<button type="button" class="btn btn-outline-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>

Tamaños del componente Grupo de botones

En lugar de aplicar clases de tamaño de botones a cada botón de un grupo, simplemente agrega .btn-group-* a cada .btn-group, incluyendo cada uno cuando se anidan varios grupos.

HTML
<div class="btn-group btn-group-lg" role="group" aria-label="Grupo de botones grandes">
<button type="button" class="btn btn-outline-primary">Izquierda</button>
<button type="button" class="btn btn-outline-primary">Medio</button>
<button type="button" class="btn btn-outline-primary">Derecha</button>
</div>
<br>
<div class="btn-group" role="group" aria-label="Grupo de botones predeterminado">
<button type="button" class="btn btn-outline-primary">Izquierda</button>
<button type="button" class="btn btn-outline-primary">Medio</button>
<button type="button" class="btn btn-outline-primary">Derecha</button>
</div>
<br>
<div class="btn-group btn-group-sm" role="group" aria-label="Grupo de botones pequeños">
<button type="button" class="btn btn-outline-primary">Izquierda</button>
<button type="button" class="btn btn-outline-primary">Medio</button>
<button type="button" class="btn btn-outline-primary">Derecha</button>
</div>

Anidamiento del componente Grupo de botones

Coloca un .btn-group dentro de otro .btn-group cuando quieras menús desplegables mezclados con una serie de botones.

HTML
<div class="btn-group" role="group" aria-label="Grupo de botones con menú desplegable anidado">
<button type="button" class="btn btn-primary">1</button>
<button type="button" class="btn btn-primary">2</button>
<div class="btn-group" role="group">
<button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown"
aria-expanded="false">
Desplegable
</button>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
</ul>
</div>
</div>

Variación vertical del componente Grupo de botones

Haz que un conjunto de botones aparezcan apilados verticalmente en lugar de horizontalmente. Aquí no se admiten menús desplegables de botones divididos.

HTML
<div class="btn-group-vertical" role="group" aria-label="Grupo de botones verticales">
<button type="button" class="btn btn-primary">Botón</button>
<button type="button" class="btn btn-primary">Botón</button>
<button type="button" class="btn btn-primary">Botón</button>
<button type="button" class="btn btn-primary">Botón</button>
</div>
HTML
<div class="btn-group-vertical" role="group" aria-label="Grupo de botones verticales">
<button type="button" class="btn btn-primary">Botón</button>
<button type="button" class="btn btn-primary">Botón</button>
<div class="btn-group" role="group">
<button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
Desplegable
</button>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
</ul>
</div>
<div class="btn-group dropstart" role="group">
<button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
Desplegable
</button>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
</ul>
</div>
<div class="btn-group dropend" role="group">
<button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
Desplegable
</button>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
</ul>
</div>
<div class="btn-group dropup" role="group">
<button type="button" class="btn btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-expanded="false">
Desplegable
</button>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
<li><a class="dropdown-item" href="#">Enlace desplegable</a></li>
</ul>
</div>
</div>
HTML
<div class="btn-group-vertical" role="group" aria-label="Grupo de botones de alternancia vertical">
<input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio1" autocomplete="off" checked="">
<label class="btn btn-outline-danger" for="vbtn-radio1">Radio 1</label>
<input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio2" autocomplete="off">
<label class="btn btn-outline-danger" for="vbtn-radio2">Radio 2</label>
<input type="radio" class="btn-check" name="vbtn-radio" id="vbtn-radio3" autocomplete="off">
<label class="btn btn-outline-danger" for="vbtn-radio3">Radio 3</label>
</div>