Índice z y contextos de apilamiento

Supongamos que tiene un par de elementos que están absolutamente posicionados, y deben ubicarse una encima de la otra. Puedes escribir un poco de HTML como el siguiente:

<div class="stacked-items">
    <div class="item-1">Item 1</div>
    <div class="item-2">Item 2</div>
</div>

Pero ¿cuál se ubica encima de la otra de forma predeterminada? Para saber qué elemento haría eso, debes entender el índice z y los contextos de apilamiento.

Índice z

La z-index establece de manera explícita un orden de capas para HTML basado en el espacio 3D del navegador: el eje Z. Este es el eje que muestra qué capas están más cerca y más lejos de ti. El eje vertical en la web es el eje Y, y el eje horizontal es el eje X.

Cada eje que rodea el elemento

La propiedad z-index acepta un valor numérico que puede ser positivo o negativo. Los elementos aparecerán sobre otro si tienen un valor de z-index más alto. Si no se establece un z-index en tus elementos el comportamiento predeterminado es que el orden de la fuente del documento determina el eje Z. Esto significa que los elementos que están más abajo en el documento se ubican sobre los que aparecen antes de ellos.

En un flujo normal, Si estableces un valor específico para z-index y no funciona, Debes establecer el valor position del elemento en un valor distinto de static. Este es un lugar común donde las personas tienen problemas con z-index.

Sin embargo, este no es el caso si estás en un contexto de flexbox o cuadrícula. porque puedes modificar el índice z de los elementos flexibles o de cuadrícula sin agregar position: relative.

Índice z negativo

Para colocar un elemento detrás de otro, haz lo siguiente: agregar un valor negativo para z-index.

.my-element {
    background: rgb(232 240 254 / 0.4);
}

.my-element .child {
    position: relative;
    z-index: -1;
}

Mientras .my-element tenga el valor inicial de z-index de auto, el elemento .child se ubicará detrás de él.

Agrega el siguiente CSS a .my-element: y el elemento .child no se ubicará detrás de él.

.my-element {
  position: relative;
  z-index: 0;
  background: rgb(232 240 254 / 0.4);
}

Porque ahora .my-element tiene un valor position que no es static y un valor z-index que no sea auto, Se creó un nuevo contexto de pila. Esto significa que, incluso si configuras .child para que tenga un z-index de -999, aun así no se quedaría detrás de .my-parent.

Contexto de apilado

Un contexto de apilado es un grupo de elementos que tienen un elemento superior común y se mueven juntos hacia arriba y hacia abajo en el eje z.

En este ejemplo, el primer elemento superior tiene un z-index de 1, lo que crea un nuevo contexto de apilado. Su elemento secundario tiene un z-index de 999. Junto a este elemento superior, hay otro elemento superior con un elemento secundario. El elemento superior tiene un z-index de 2 y el elemento secundario también tiene un z-index de 2. Debido a que ambos elementos superiores crean un contexto de apilado, El z-index de todos los elementos secundarios se basa en el del elemento superior.

El z-index de los elementos dentro de un contexto de pila siempre son relativas al orden actual del elemento superior en su propio contexto de apilado.

Crear un contexto de pila

No es necesario que apliques z-index ni position para crear una nueva contexto de pila. Puedes crear un nuevo contexto de apilado agregando un valor para las propiedades que crean una nueva capa compuesta. como opacity, will-change y transform. Puedes consulta la lista completa de propiedades aquí.

Para explicar qué es una capa compuesta, imagina que una página web es un lienzo. Un navegador toma tu código HTML y CSS, y los usa para decidir qué tan grande es el lienzo. Luego pinta la página en este lienzo. Si un elemento cambiara, digamos cambia de posición: el navegador tiene que regresar y rehacer qué pintar.

Para mejorar el rendimiento el navegador crea nuevas capas compuestas que se superponen al lienzo. Son un poco como notas adhesivas: mover una y cambiarla no tiene un gran impacto en el lienzo general. Se crea una nueva capa compuesta para elementos con opacity, transform y will-change porque es muy probable que cambien, para que el navegador se asegure de que el cambio tenga el mejor rendimiento posible usando la GPU para aplicar los ajustes de estilo.

Recursos

Verifica tus conocimientos

Pon a prueba tus conocimientos sobre el índice z

<section>
  <article>1</article>
  <article>2</article>
  <article>3</article>
  <article>4</article>
</section>

¿Cuál de los siguientes artículos aparece en la parte superior de forma predeterminada?

1
4
2
3

Si el índice z no funciona, ¿qué propiedad deberías inspeccionar en el elemento?

position
animation
relative
display

¿flexbox y la cuadrícula necesitan position: relative?

No