CSS estable, potente y digno de la caja de herramientas que puedes usar hoy mismo.
Creo que todos los desarrolladores frontend deben saber cómo usar consultas de contenedor, crear una experiencia de ajuste de desplazamiento, evitar position: absolute
con cuadrícula, marcar un círculo con rapidez, usar capas en cascada y llegar a más con menos mediante las propiedades lógicas. A continuación, se incluye una breve descripción general de cada una de esas expectativas.
1. Una consulta de contenedor
La función de CSS más solicitada durante 10 años consecutivos ahora es estable en todos los navegadores y está disponible para que la uses en las consultas de ancho en 2023.
.panel {
container: layers-panel / inline-size;
}
.card {
padding: 1rem;
}
@container layers-panel (min-width: 20rem) {
.card {
padding: 2rem;
}
}
2. Ajuste de desplazamiento
Las experiencias de desplazamiento bien orquestadas te diferencian del resto, y el ajuste del desplazamiento es la forma perfecta de hacer coincidir la UX de desplazamiento del sistema y, al mismo tiempo, proporcionar puntos de detención significativos.
.snaps {
overflow-x: scroll;
scroll-snap-type: x mandatory;
overscroll-behavior-x: contain;
}
.snap-target {
scroll-snap-align: center;
}
.snap-force-stop {
scroll-snap-stop: always;
}
Obtén más información sobre el potencial de esta función de CSS en esta colección inspiradora y enorme de CodePen de alrededor de 25 demostraciones.
scroll-snap-type
scroll-snap-align
scroll-snap-stop
overscroll-behavior
3. Pila de rejilla
Evita la posición absoluta con una cuadrícula CSS de una sola celda. Una vez que estén apilados uno sobre el otro, usa las propiedades de justificación y alineación para posicionarlos.
.pile {
display: grid;
place-content: center;
}
.pile > * {
grid-area: 1/1;
}
grid
4. Círculo rápido
Existen muchas formas de hacer círculos en CSS, pero esta es, sin duda, la más mínima.
.circle {
inline-size: 25ch;
aspect-ratio: 1;
border-radius: 50%;
}
aspect-ratio
5. Controla las variantes con @layer
Las capas en cascada pueden ayudar a insertar variantes descubiertas o creadas más adelante en el lugar correcto de la cascada con el conjunto original de variantes.
/* file buttons.css */
@layer components.buttons {
.btn.primary {
…
}
}
Luego, en un archivo completamente diferente, cargado en otro momento aleatorio, agrega una variante nueva a la capa del botón como si estuviera allí con el resto todo el tiempo.
/* file video-player.css */
@layer components.buttons {
.btn.player-icon {
…
}
}
@layer
6. Memoriza menos y alcanza más con propiedades lógicas
Memoriza este modelo de un nuevo cuadro
y nunca tendrás que preocuparte por
cambiar el padding o el margen izquierdo y derecho para los modos de escritura y las
direcciones de los documentos internacionales.
Ajusta tus estilos de propiedades físicas a propiedades lógicas, como padding-inline
, margin-inline
y inset-inline
, y el navegador hará el trabajo de ajuste.
button {
padding-inline: 2ch;
padding-block: 1ch;
}
article > p {
text-align: start;
margin-block: 2ch;
}
.something::before {
inset-inline: auto 0;
}