Damián De Luca - Capacitación & Desarrollo Web

Formularios con Bootstrap

Bootstrap
Maquetar formularios con Bootstrap

Entre las soluciones que podemos encontrar para crear interfaces web modernas e interactivas, Bootstrap es una solución muy recomendable. Dentro de las ventajas que aporta este popular framework front-end, encontramos excelentes características para la construcción de formularios.

Diseñado para simplificar el armado de sitios web adaptables y eficientes, Bootstrap ofrece una manera coherente y amigable de integrar formularios en nuestros proyectos. Esto resulta una alternativa muy útil, tanto para maquetadores web, como también para programadores, a la hora de armar diferentes soluciones y ahorrar tiempo.

En este artículo, exploraremos las características clave que ofrece Bootstrap para maquetar formularios, sus ventajas, cómo personalizarlos, y los aspectos importantes a tener en cuenta. También veremos cómo integrarlos de manera sencilla en un sitio web.

Ventajas de los formularios en Bootstrap

Una de las principales ventajas de usar Bootstrap para formularios es que estos se ajustan automáticamente a diferentes tamaños de pantalla, lo que garantiza una experiencia de usuario consistente tanto en dispositivos móviles como en escritorio.

Bootstrap adopta el modelo de diseño “mobile-first”, asegurando que los formularios luzcan bien desde el primer momento, sin importar el tamaño del dispositivo.

<form>
  <div class="mb-3">
    <label for="exampleInputEmail1" class="form-label">Correo electrónico</label>
    <input type="email" class="form-control" id="exampleInputEmail1" aria-describedby="emailHelp">
  </div>
  <div class="mb-3">
    <label for="exampleInputPassword1" class="form-label">Contraseña</label>
    <input type="password" class="form-control" id="exampleInputPassword1">
  </div>
  <button type="submit" class="btn btn-primary">Enviar</button>
</form>

Componentes predefinidos

Bootstrap viene con una amplia gama de componentes predefinidos que facilitan la construcción de formularios de manera rápida y eficiente. Esto incluye:

Todos estos elementos siguen las pautas de accesibilidad y están optimizados para funcionar en una variedad de navegadores y dispositivos.

Validación de formularios

Bootstrap incluye validación de formularios incorporada, lo que facilita la creación de formularios con feedback inmediato. Con solo agregar clases como was-validated o is-invalid, puedes controlar cómo se muestran los mensajes de error y los estados de validación.

<form class="was-validated">
  <div class="mb-3">
    <label for="validationTextarea" class="form-label">Comentario</label>
    <textarea class="form-control is-invalid" id="validationTextarea" required></textarea>
    <div class="invalid-feedback">
      Por favor ingresa un comentario válido.
    </div>
  </div>
  <button type="submit" class="btn btn-primary">Enviar</button>
</form>

Personalización con SASS

Bootstrap permite personalizar los estilos de los formularios a través de variables SASS. Esto significa que puedes ajustar la apariencia de tus formularios para alinearlos con la identidad visual de tu proyecto, modificando aspectos como colores, bordes, tamaño de las fuentes, entre otros.

Por ejemplo, si quieres cambiar el color de los campos de entrada:

$input-border-color: #3498db;
$input-focus-border-color: #2ecc71;
$input-bg: #ecf0f1;

Para comprender como trabajar con SASS y Bootstrap recomiendo leer la documentación: https://getbootstrap.com/docs/5.3/customize/sass/.

Soporte para Grid System

Los formularios en Bootstrap son compatibles con el sistema de grillas (grid system), lo que te permite crear formularios complejos y bien alineados de manera sencilla. Ya sea un formulario simple o un formulario más avanzado con múltiples columnas, puedes organizarlos de forma flexible usando el grid.

<form>
  <div class="row mb-3">
    <div class="col">
      <input type="text" class="form-control" placeholder="Nombre">
    </div>
    <div class="col">
      <input type="text" class="form-control" placeholder="Apellido">
    </div>
  </div>
  <button type="submit" class="btn btn-primary">Enviar</button>
</form>

Personalización de formularios

Una de las grandes ventajas de Bootstrap es su facilidad de personalización. Podemos cambiar los estilos por defecto utilizando características de CSS o SASS. Además, Bootstrap permite personalizar elementos individuales de formularios, como botones, campos de texto, selectores, entre otros.

Con Bootstrap, podremos personalizar los botones de los formularios con diferentes clases. Los botones pueden ser de distintos estilos (primario, secundario, éxito, peligro, etc.) y pueden personalizarse aún más utilizando variables CSS.

En el siguiente código HTML veremos como crear un botón del tipo submit.

<button type="submit" class="btn btn-success">Enviar</button>

Formularios flotantes

Otra característica interesante es la capacidad de crear formularios flotantes con estilos modernos, usando las clases .form-floating para agregar una etiqueta encima del campo de entrada.

A continuación veremos un ejemplo de como se puede crear este tipo de elemento:

<div class="form-floating mb-3">
  <input type="email" class="form-control" id="floatingInput" placeholder="name@example.com">
  <label for="floatingInput">Correo electrónico</label>
</div>

Aspectos a tener en cuenta al crear formularios en Bootstrap

A pesar de sus numerosas ventajas, Bootstrap también tiene algunos aspectos que debemos considerar:

  1. Estilos genéricos por defecto. Aunque los formularios en Bootstrap son atractivos y funcionales, pueden resultar en una apariencia genérica si no se personalizan. Es recomendable usar las opciones de personalización para que tus formularios se ajusten al branding de tu sitio.
  2. Se requiere de conocimientos de CSS y SASS para personalización avanzada. La personalización general se puede realizar con CSS, para esto debemos tener conocimiento de su sintaxis y reglas. Y si bien podemos personalizar los estilos completos desde CSS, para algunos proyectos podría ser recomendable trabajar con SASS, especialmente cuando necesitamos escalabilidad y trabajar en equipo.

Integrar formularios Bootstrap en nuestro sitio

Para integrar formularios de Bootstrap en una web, podemos seguir los siguientes pasos:

  1. Incluir Bootstrap en un proyecto

Para comenzar es necesario incorporar Bootstrap en el proyecto. Se puede agregar en la sección <head> de tu archivo HTML, como veremos a continuación:

<link href="css/bootstrap.min.css" rel="stylesheet">

Si vamos a usar características interactivas y validaciones es importante agregar también el script que incluye las funcionalidades de Bootstrap. Este archivo de extensión js, puede incorporarse en diferentes lugares de la página HTML, pero puede ser una buena opción incluirlo en la parte inferior.

El código para agregar el script en un HTML es el siguiente:

<script src="js/bootstrap.bundle.min.js"></script>

En los ejemplos anteriores se asume que los archivos están ubicados con esos nombres en las carpetas css y js (respectivamente). Los archivos se pueden obtener desde los enlaces del sitio oficial de Bootstrap.

Vale aclarar que también es posible incorporar Bootstrap en un proyecto mediante el uso de gestores de paquetes (como npm) o vía CDN. La explicación detallada sobre los pasos para utilizar alguna de estas opciones están disponibles en: https://getbootstrap.com/.

  1. Crear el Formulario

A continuación, podremos comenzar a crear los formularios utilizando las clases de Bootstrap para obtener un diseño clásico de Bootstrap.

Veamos un ejemplo clásico, donde se pide al usuario nombre y correo electrónico. También se incluye el botón enviar.

<form>
  <div class="mb-3">
    <label for="name" class="form-label">Nombre</label>
    <input type="text" class="form-control" id="name" required>
  </div>
  <div class="mb-3">
    <label for="email" class="form-label">Correo electrónico</label>
    <input type="email" class="form-control" id="email" required>
  </div>
  <button type="submit" class="btn btn-primary">Enviar</button>
</form>

Es importante mencionar que este ejemplo es solo la maqueta y para que tome los estilos requiere de que los estilos de Bootstrap estén incorporados en el proyecto. También debemos saber que en el ejemplo no incluyo la parte de programación.

  1. Personalizar con CSS o SASS

Si necesitamos personalizar el aspecto de tu formulario, puedes hacerlo con CSS personalizado o editando las variables de SASS proporcionadas por Bootstrap.

La mejor forma de hacerlo es vincular un archivo CSS. Lo podemos hacer de la siguiente forma:

<link href="css/estilos.css" rel="stylesheet">

Para trabajar sin interferencias, es muy importante conocer como trabaja Bootstrap, especialmente en el tema de clases. En este sentido debemos tener en cuenta que, para la visualización de los estilos en el navegador, entra en juego todo lo relacionado con especificidad y cascada.

En conclusión

Bootstrap es una excelente herramienta para crear formularios modernos, accesibles y adaptables. Su facilidad de uso, amplia gama de componentes y capacidad de personalización hacen que sea una opción ideal para la mayoría de los proyectos web.

Con la planificación adecuada y el conocimiento sobre Bootstrap y CSS resultará simple integrar formularios en nuestros sitios y ajustarlos a las necesidades específicas de cada uno de ellos.

Para saber más sobre formularios podremos consultar la documentación oficial de Bootstrap sobre este tema en el siguiente enlace: https://getbootstrap.com/docs/5.3/forms/overview/.

Si te surge alguna consulta o si interesa saber más sobre Bootstrap déjame un comentario o escríbeme un mensaje.

Salir de la versión móvil