Saltar al contenido principal

[Medium] 🏷️ Unidades CSS

1. Explique la diferencia entre px, em, rem, vw, vh

Tabla de comparación rápida

UnidadTipoRelativo aAfectado por padreUsos comunes
pxAbsolutaPíxeles de pantallaBordes, sombras, detalles pequeños
emRelativafont-size del padrePadding, margin (seguir fuente)
remRelativafont-size del rootFuentes, espaciado, tamaño general
vwRelativa1% del ancho del viewportAncho responsivo, elementos de ancho completo
vhRelativa1% del alto del viewportAlto responsivo, secciones de pantalla completa

Explicación detallada

px (Pixels)

Definición: Unidad absoluta, 1px = un punto de píxel en la pantalla

Características:

  • Tamaño fijo, no cambia por ninguna configuración
  • Control preciso, pero carece de flexibilidad
  • No es favorable para diseño responsivo ni accesibilidad

Cuándo usar:

/* ✅ Adecuado para */
border: 1px solid #000; /* Bordes */
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* Sombras */
border-radius: 4px; /* Bordes redondeados pequeños */

/* ❌ No recomendado para */
font-size: 16px; /* Para fuentes se recomienda rem */
width: 1200px; /* Para ancho se recomienda % o vw */

em

Definición: Múltiplo del font-size del elemento padre

Características:

  • Se acumula por herencia (las estructuras anidadas se apilan)
  • Alta flexibilidad pero puede descontrolarse fácilmente
  • Adecuado para escenarios que necesitan escalar con el padre

Ejemplo de cálculo:

.parent {
font-size: 16px;
}

.child {
font-size: 1.5em; /* 16px × 1.5 = 24px */
padding: 1em; /* 24px × 1 = 24px (relativo a su propio font-size) */
}

.grandchild {
font-size: 1.5em; /* 24px × 1.5 = 36px (efecto acumulativo!) */
}

Cuándo usar:

/* ✅ Adecuado para */
.button {
font-size: 1rem;
padding: 0.5em 1em; /* Padding sigue el tamaño de fuente del botón */
}

.card-title {
font-size: 1.2em; /* Relativo a la fuente base de la tarjeta */
margin-bottom: 0.5em; /* Espaciado sigue el tamaño del título */
}

/* ⚠️ Cuidado con la acumulación por anidamiento */

rem (Root em)

Definición: Múltiplo del font-size del elemento raíz (<html>)

Características:

  • No se acumula por herencia (siempre relativo al root)
  • Fácil de gestionar y mantener
  • Conveniente para implementar escalado global
  • Una de las unidades más recomendadas

Ejemplo de cálculo:

html {
font-size: 16px; /* Valor predeterminado del navegador */
}

.element {
font-size: 1.5rem; /* 16px × 1.5 = 24px */
padding: 2rem; /* 16px × 2 = 32px */
margin: 1rem 0; /* 16px × 1 = 16px */
}

.nested .element {
font-size: 1.5rem; /* Sigue siendo 24px, no se acumula! */
}

Cuándo usar:

/* ✅ Más recomendado para */
html {
font-size: 16px; /* Establecer base */
}

body {
font-size: 1rem; /* Texto principal 16px */
}

h1 {
font-size: 2.5rem; /* 40px */
}

p {
font-size: 1rem; /* 16px */
margin-bottom: 1rem; /* 16px */
}

.container {
padding: 2rem; /* 32px */
max-width: 75rem; /* 1200px */
}

/* ✅ Conveniente para modo oscuro o ajustes de accesibilidad */
@media (prefers-reduced-motion: reduce) {
html {
font-size: 18px; /* Todas las unidades rem se amplían automáticamente */
}
}

vw (Viewport Width)

Definición: 1% del ancho del viewport (100vw = ancho del viewport)

Características:

  • Verdadera unidad responsiva
  • Cambia en tiempo real con el tamaño del viewport del navegador
  • Nota: 100vw incluye el ancho de la barra de desplazamiento

Ejemplo de cálculo:

/* Asumiendo ancho de viewport 1920px */
.element {
width: 50vw; /* 1920px × 50% = 960px */
font-size: 5vw; /* 1920px × 5% = 96px */
}

/* Asumiendo ancho de viewport 375px (móvil) */
.element {
width: 50vw; /* 375px × 50% = 187.5px */
font-size: 5vw; /* 375px × 5% = 18.75px */
}

Cuándo usar:

/* ✅ Adecuado para */
.hero {
width: 100vw; /* Banner de ancho completo */
margin-left: calc(-50vw + 50%); /* Romper límite del contenedor */
}

.hero-title {
font-size: clamp(2rem, 5vw, 5rem); /* Fuente responsiva */
}

.responsive-box {
width: 80vw;
max-width: 1200px; /* Agregar límite máximo */
}

/* ❌ Evitar */
body {
width: 100vw; /* Causará barra de desplazamiento horizontal (incluye barra de desplazamiento) */
}

vh (Viewport Height)

Definición: 1% del alto del viewport (100vh = alto del viewport)

Características:

  • Adecuado para crear efectos de pantalla completa
  • En dispositivos móviles hay que tener en cuenta el problema de la barra de direcciones
  • Puede verse afectado por la aparición del teclado

Cuándo usar:

/* ✅ Adecuado para */
.hero-section {
height: 100vh; /* Página principal de pantalla completa */
}

.fullscreen-modal {
height: 100vh;
width: 100vw;
}

.sidebar {
height: 100vh;
position: sticky;
top: 0;
}

/* ⚠️ Alternativa para dispositivos móviles */
.hero-section {
height: 100vh;
height: 100dvh; /* Alto dinámico del viewport (unidad más nueva) */
}

/* ✅ Centrado vertical */
.center-content {
min-height: 100vh;
display: flex;
align-items: center;
justify-content: center;
}

Consejos prácticos y mejores prácticas

1. Construir sistema de fuentes responsivo

/* Establecer base */
html {
font-size: 16px; /* Valor predeterminado de escritorio */
}

@media (max-width: 768px) {
html {
font-size: 14px; /* Tableta */
}
}

@media (max-width: 480px) {
html {
font-size: 12px; /* Móvil */
}
}

/* Todos los elementos que usan rem se escalan automáticamente */
h1 {
font-size: 2.5rem;
} /* Escritorio 40px, móvil 30px */
p {
font-size: 1rem;
} /* Escritorio 16px, móvil 12px */

2. Uso mixto de diferentes unidades

.card {
/* Ancho responsivo + rango limitado */
width: 90vw;
max-width: 75rem;

/* rem para espaciado */
padding: 2rem;
margin: 1rem auto;

/* px para detalles */
border: 1px solid #ddd;
border-radius: 8px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.card-title {
/* clamp combina múltiples unidades, escalado fluido */
font-size: clamp(1.25rem, 3vw, 2rem);
}

Ejemplo de respuesta para entrevista

Estructura de respuesta:

1. **px**: Detalles en píxeles → bordes, sombras, bordes redondeados
2. **rem**: Base estable desde la raíz → fuentes, espaciado, tamaños principales
3. **em**: Sigue al padre
4. **vw**: Cambia con el ancho del viewport → ancho responsivo
5. **vh**: Llena el alto del viewport → secciones de pantalla completa
  1. Definición rápida

    • px es unidad absoluta, las demás son relativas
    • em es relativo al padre, rem es relativo al root
    • vw/vh son relativos al tamaño del viewport
  2. Diferencia clave

    • rem no se acumula, em sí (esta es la diferencia principal)
    • vw/vh son verdaderamente responsivos, pero hay que tener cuidado con la barra de desplazamiento
  3. Aplicación práctica

    • px: Bordes de 1px, sombras y otros detalles
    • rem: Fuentes, espaciado, contenedores (el más usado, fácil de mantener)
    • em: Padding de botones (cuando necesita escalar con la fuente)
    • vw/vh: Banners de ancho completo, secciones de pantalla completa, fuentes responsivas con clamp
  4. Mejores prácticas

    • Establecer html font-size como base
    • Usar clamp() para combinar diferentes unidades
    • Tener cuidado con el problema de vh en dispositivos móviles (se puede usar dvh)

Reference