Flexbox en CSS, cómo funciona y ejemplos

Un hombre caminando con una caja azul en su cabeza. Diseño de experiencia de usuario (UX).

En el mundo digital actual, donde la diversidad de dispositivos y tamaños de pantalla impera, la flexibilidad y adaptabilidad son claves para una experiencia de usuario (UX) óptima. Desde la disposición de los elementos hasta la interacción fluida, cada detalle cuenta para crear un entorno digital atractivo y funcional. En este contexto, la propiedad CSS flexbox se convierte en una herramienta indispensable para los expertos UX, ofreciendo una amplia gama de opciones para diseñadores y desarrolladores. En este artículo, exploraremos en profundidad la propiedad CSS Flexbox, sus características y aplicaciones en el diseño UX.

¿Qué es CSS Flexbox?

Flexbox, CSS Flexbox o Flexible Box Layout, es un módulo de diseño CSS que permite distribuir elementos en un contenedor de forma flexible y adaptable. A diferencia de los métodos tradicionales como float o display: table, flexbox ofrece un mayor control sobre la disposición de los elementos, tanto en horizontal como en vertical, adaptándose dinámicamente al tamaño y disposición de los elementos en un contenedor.

Introducido en CSS3, Flexbox proporciona un control preciso sobre el posicionamiento y alineación de los elementos, tanto en el eje principal como en el transversal. Esto lo convierte en un recurso imprescindible para el diseño responsive.

Opciones que ofrece Flexbox

Distribución automática de espacio
Flexbox distribuye automáticamente el espacio disponible dentro de un contenedor entre los elementos hijos, lo que simplifica la creación de diseños responsivos y adaptables.

Justificación del contenido
Permite alinear los elementos del contenedor a la izquierda, derecha, centro o distribuirlos uniformemente.

Alineación flexible
Permite alinear elementos de manera flexible en el eje principal y transversal, incluyendo opciones como centrado, distribución equitativa y alineación a los extremos.

Ordenar elementos
Es posible reorganizar visualmente los elementos sin cambiar el orden en el código HTML, lo que facilita la adaptación del diseño según el contexto y los requisitos de UX.

Imagen de jannoon028

Espaciado entre elementos
Flexbox ofrece control sobre el espacio entre elementos, permitiendo establecer espacios uniformes o variables según sea necesario.

Dirección del layout
Permite definir si los elementos se distribuyen en una sola fila o columna, o si se apilan uno encima del otro.

Flexbox wrap
Permite que los elementos se “envuelvan” a la siguiente línea cuando no caben en la actual.

Crecimiento y contracción
Define cómo se ajustan los elementos al tamaño del contenedor, pudiendo crecer o contraerse según sea necesario.

¿Cómo utilizar CSS Flexbox?

Al ser Flexbox un módulo completo, podemos utilizarlo modificando una serie de propiedades. Algunas de ellas deben aplicarse en el contenedor “padre”, mientras que otras deben aplicarse en los contenedores que hay en el interior del padre, los “hijos”.

Propiedades del contenedor padre

display

Define un contenedor padre. Puede ser en línea o en bloque dependiendo del valor dado. Además, permite un contexto flexible para todos sus hijos directos.

.padre {
  display: flex;
  display: inline-flex;
}

flex-direction

Establece el eje principal, definiendo así la dirección en la que se colocan los hijos en el contenedor padre. Los hijos se pueden disponer principalmente en filas horizontales o columnas verticales.

.padre {
  flex-direction: row;
  flex-direction: row-reverse;
  flex-direction: column;
  flex-direction: column-reverse;
}

flex-wrap

Por defecto, todos los hijos intentarán mantenerse alineados. Esta propiedad permite que los hijos se ajusten según la posición necesaria.

.padre {
  flex-wrap: nowrap;
  flex-wrap: wrap;
  flex-wrap: wrap-reverse;
}

flex-flow

Una abreviatura de las dos propiedades anteriores, flex-direction y flex-wrap, que juntas definen los ejes principal y transversal del contenedor padre.

.padre {
  flex-direction: column;
  flex-wrap: wrap;
---------------------------
  flex-flow: column wrap;
}

justify-content

Define la alineación a lo largo del eje principal. Ayuda a distribuir el espacio libre adicional sobrante cuando todos los hijos de una línea son inflexibles o son flexibles pero han alcanzado su tamaño máximo. También ejerce cierto control sobre la alineación de los hijos cuando desbordan la línea.

.padre {
  justify-content: flex-start,
  justify-content: flex-end;
  justify-content: center;
  justify-content: space-between;
  justify-content: space-around;
  justify-content: space-evenly;
}

align-items

Define el comportamiento predeterminado de cómo se distribuyen los hijos a lo largo del eje transversal de la línea actual. Puede considerarse como la versión de justificación de contenido para el eje transversal (perpendicular al eje principal).

.padre {
  align-items: stretch;
  align-items: flex-start;
  align-items: flex-end;
  align-items: center;
  align-items: baseline;
  align-items: first baseline;
  align-items: last baseline;
}

align-content

Alinea las líneas de un contenedor padre cuando hay espacio adicional en el eje transversal, similar a cómo justificar contenido alinea hijos individuales dentro del eje principal.

.padre {
  align-content: flex-start;
  align-content: flex-end;
  align-content: center;
  align-content: stretch;
  align-content: space-between;
  align-content: space-around;
}

gap, row-gap, column-gap

La propiedad gap o “hueco” controla explícitamente el espacio entre hijos. Se aplica ese espacio solo entre hijos y no en los bordes exteriores.

.padre {
  display: flex;
  gap: 10px;
  gap: 10px 30px;
  row-gap: 10px;
  column-gap: 30px;
}

Propiedades del contenedor hijo

order

Predeterminadamente los hijos se muestran por orden de origen. La propiedad order controla el orden en que aparecen en el contenedor padre.

.hijo {
  order: 5;
}

flex-grow

Define la capacidad de un hijo de crecer (aumentar de tamaño) si es necesario. Acepta un valor sin unidades que sirve como proporción. Indica qué cantidad de espacio disponible dentro del contenedor padre debe ocupar el artículo.

Si todos los hijos tienen flex-grow configurado en 1, el espacio restante en el contenedor se distribuirá equitativamente entre todos los niños. Si uno de los hijos tiene un valor de 2, ese hijo ocuparía el doble de espacio que los demás (o lo intentará, al menos).

.hijo {
  flex-grow: 4;
}

flex-shrink

Define la capacidad de un hijo de reducir su tamaño si es necesario.

.hijo {
  flex-shrink: 3;
}

flex-basis

Define el tamaño predeterminado de un hijo antes de que se distribuya el espacio restante. Puede ser una longitud (por ejemplo, 20%, 5rem, etc.) o una palabra clave (por ejemplo auto o max-content).

.hijo {
  flex-basis: 1rem;
}

align-self

Permite anular la alineación predeterminada (o la especificada por align-items) individualmente por cada hijo.

.hijo {
  align-self: auto;
  align-self: flex-start;
  align-self: flex-end;
  align-self: center;
  align-self: baseline;
  align-self: stretch;
}

Aplicaciones de Flexbox en el diseño UX

Diseño de interfaces responsive
CSS Flexbox es una herramienta invaluable para crear interfaces que se adapten a diferentes dispositivos y tamaños de pantalla de manera fluida. Al permitir una distribución automática del espacio, los diseñadores pueden crear diseños que se ajusten sin problemas a cualquier resolución, mejorando así la experiencia del usuario en diversos dispositivos

Diseño de interfaces intuitivas
También permite crear interfaces con elementos que se ajustan a las acciones del usuario, mejorando la usabilidad. A nivel de navegación, Flexbox también permite crear una navegación web que se adapta a diferentes tamaños de pantalla, mostrando u ocultando elementos según sea necesario.

Imagen de pressfoto

Cuadrículas flexibles de contenido
Crear cuadrículas de contenido flexibles es una tarea común en el diseño web. Con Flexbox, los diseñadores pueden construir cuadrículas dinámicas que se ajusten automáticamente al contenido, garantizando una presentación visualmente atractiva y una experiencia de usuario fluida.

Animaciones y transiciones
Flexbox facilita la creación de animaciones y transiciones fluidas entre diferentes estados de la interfaz. El módulo permite definir con precisión la posición y el comportamiento de los elementos, lo que es fundamental para crear animaciones y transiciones fluidas y coherentes.

Ejemplos prácticos

Menús de navegación flexibles
Los menús de navegación son elementos fundamentales en la experiencia del usuario. Con Flexbox, es posible diseñar menús que se expandan o contraigan según sea necesario, optimizando el espacio disponible y facilitando la navegación en dispositivos móviles.

Diseño de formularios
Los formularios son componentes esenciales en muchos sitios web y aplicaciones. Utilizando Flexbox, es posible diseñar formularios que se adapten a diferentes longitudes de campo y dispositivos, mejorando la usabilidad y accesibilidad para los usuarios.

Imagen de Jason Goodman

Galerías de imágenes flexibles
Las galerías de imágenes son otro ejemplo donde Flexbox brilla. Los diseñadores pueden crear galerías que se ajusten dinámicamente al tamaño de la pantalla, manteniendo la proporción de las imágenes y ofreciendo una experiencia visualmente agradable en cualquier dispositivo.

Tarjetas de contenido
Al utilizar Flexbox, las tarjetas de contenido pueden diseñarse para adaptarse fácilmente a diferentes tamaños de pantalla y dispositivos móviles, lo que mejora la experiencia del usuario en dispositivos móviles y tabletas. También es posible alinear y espaciar los elementos dentro de las tarjetas de contenido de manera flexible y personalizada, lo que permite crear diseños visualmente atractivos y bien organizados.

En resumen, CSS Flexbox es una herramienta poderosa para diseñadores UX. Aprovecha sus propiedades para crear interfaces más flexibles y atractivas.

¡Explora y experimenta con Flexbox para mejorar tus habilidades de diseño!

¡Comparte este post!

Fotografía de perfil de Ramon Bosch Pérez.

Escribe un comentario

Sigue leyendo

Ir al contenido