The CSS Podcast - 017: Shadows
Supongamos que te enviaron un diseño para compilar y, en ese diseño, hay una foto de una camiseta cortada con una sombra. El diseñador te dice que la imagen del producto es dinámica y se puede actualizar a través del sistema de administración de contenido, por lo que la sombra también debe ser dinámica. En lugar de una camiseta, la imagen puede ser un visor, pantalones cortos o cualquier otro elemento. ¿Cómo lo haces con CSS?
CSS tiene las propiedades box-shadow
y text-shadow
, pero la imagen no es texto, por lo que no puedes usar text-shadow
.
Si usas box-shadow
, la sombra está en el cuadro circundante, no alrededor de la camiseta.
Por suerte, hay otra opción: el filtro drop-shadow()
.
Esto te permite hacer exactamente lo que pidió el diseñador.
Hay muchas opciones en cuanto a las sombras en CSS, cada una diseñada para un caso de uso diferente.
Sombra difuminada
La propiedad box-shadow
se usa para agregar sombras al cuadro de un elemento HTML.
Funciona en elementos de bloque y elementos intercalados.
.my-element {
box-shadow: 5px 5px 20px 5px #000;
}
El orden de los valores de box-shadow
es el siguiente:
- Desplazamiento horizontal: Un número positivo lo empuja hacia la izquierda y un número negativo lo empuja hacia la derecha.
- Desplazamiento vertical: Un número positivo lo empuja hacia abajo desde la parte superior, y un número negativo lo empuja hacia arriba desde la parte inferior.
- Radio de desenfoque: Un número más alto produce una sombra más desenfocada, mientras que un número pequeño produce una sombra más nítida.
- Radio de propagación (opcional): Un número mayor aumenta el tamaño de la sombra y un número menor lo disminuye, lo que hace que tenga el mismo tamaño que el radio de desenfoque si se establece en 0.
- Color: Cualquier valor de color válido. Si no se define, se usará el color de texto calculado.
Para hacer que una sombra de cuadro sea una sombra interna, en lugar de la sombra externa predeterminada, agrega una palabra clave inset
antes de las otras propiedades.
/* Outer shadow */
.my-element {
box-shadow: 5px 5px 20px 5px #000;
}
/* Inner shadow */
.my-element {
box-shadow: inset 5px 5px 20px 5px #000;
}
Varias sombras
Puedes agregar tantas sombras como quieras con box-shadow
.
Para lograrlo, agrega una colección de conjuntos de valores separados por comas:
.my-element {
box-shadow: 5px 5px 20px 5px darkslateblue, -5px -5px 20px 5px dodgerblue,
inset 0px 0px 10px 2px darkslategray, inset 0px 0px 20px 10px steelblue;
}
Propiedades que afectan a box-shadow
Si agregas un border-radius
a tu cuadro, también se verá afectada la forma de la sombra del cuadro.
Esto se debe a que CSS crea una sombra según la forma del cuadro, como si la luz estuviera apuntando hacia él.
.my-element {
box-shadow: 0px 0px 20px 5px darkslateblue;
border-radius: 25px;
}
Si tu cuadro con box-shadow
está en un contenedor que tiene overflow: hidden
, la sombra no saldrá de ese desbordamiento.
<div class="my-parent">
<div class="my-shadow">My shadow is hidden by my parent.</div>
</div>
.my-parent,
.my-shadow {
width: 250px;
height: 250px;
}
.my-shadow {
box-shadow: 0px 0px 20px 5px darkslateblue;
}
.my-parent {
overflow: hidden;
}
Sombra del texto
La propiedad text-shadow
es muy similar a la propiedad box-shadow
.
Solo funciona en nodos de texto.
.my-element {
text-shadow: 3px 3px 3px hotpink;
}
Los valores de text-shadow
son los mismos que los de box-shadow
y están en el mismo orden.
La única diferencia es que text-shadow
no tiene un valor spread
ni una palabra clave inset
.
Cuando agregas un box-shadow
, se recorta a la forma de tu cuadro, pero text-shadow
no tiene recorte.
Esto significa que, si el texto es completamente o semitransparente, se puede ver la sombra a través de él.
.my-element {
text-shadow: 3px 3px 3px gold;
color: rgb(0 0 0 / 70%);
}
Varias sombras
Puedes agregar tantas sombras como quieras con text-shadow
,
al igual que con box-shadow
.
Agrega una colección de conjuntos de valores separados por comas y podrás crear efectos de texto muy interesantes, como texto en 3D.
.my-element {
text-shadow: 1px 1px 0px white,
2px 2px 0px firebrick;
color: darkslategray;
}
Sombra paralela
Para lograr una sombra que siga las posibles curvas de una imagen, usa el filtro drop-shadow
de CSS.
Esta sombra se aplica a una máscara alfa, lo que la hace muy útil para agregar una sombra a una imagen recortada,
como en el caso de la introducción de este módulo.
.my-image {
filter: drop-shadow(0px 0px 10px rgba(0 0 0 / 30%))
}
El filtro drop-shadow
tiene los mismos valores que box-shadow
, pero no se permiten la palabra clave inset
ni el valor spread
. Puedes agregar tantas sombras como desees. Para ello, agrega varias instancias de valores drop-shadow
a la propiedad filter
.
Cada sombra usará la última como punto de referencia de posicionamiento.
Verifica tu comprensión
Pon a prueba tus conocimientos sobre las sombras
¿Cuál de los siguientes valores de sombra es exclusivo de box-shadow
?
inset
Solo se permiten 13 sombras de cuadro en un elemento a la vez.